一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python AES加密模塊用法分析

Python AES加密模塊用法分析

2020-11-11 00:23erlang_hell Python

這篇文章主要介紹了Python AES加密模塊用法,結合具體實例形式分析了AES加密模塊的相關使用技巧與注意事項,需要的朋友可以參考下

本文實例講述了Python AES加密模塊用法。分享給大家供大家參考,具體如下:

AES是新的一種加密模塊。在上次介紹過在C語言中如何來OpenSSL中的DES。這次我們來看看Python自帶的庫如何來使用AES來加解密。其實二者的原理還是非常像,只是說在python中來做這個事情會比C語言要簡單點,但是比起C#/Java還是有點點啰嗦。在C#/JAVA這種語言中,對于加密的源數據的處理,padding一般都會有完整的實現。我在上次C語言中也處理過這個問題。在python庫中,也是需要自己來處理這個。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
from Crypto.Cipher import AES
# padding算法
BS = 16
pad = lambda s: s + (BS - len(s) % BS) * chr(0)
unpad = lambda s : s[0:-ord(s[-1])]
# 將字符串轉換成二進制的buff塊
def parse_hex(hex_str):
 l=int(math.ceil(len(hex_str)/2))
 buf=''
 for i in range(0,l):
  s=hex_str[(i*2):((i+1)*2)]
  buf=buf+chr(int(s,16))
 return buf
# 解析加密的key
key=parse_hex("68b329da9893e34099c7d8ad5cb9c940")
iv=parse_hex("68b329da9893e34099c7d8ad5cb9c940")
# 新建一個AES的對象
aes_obj = AES.new(key, AES.MODE_CBC,iv)
# 做字節對齊
padding_zero=pad(raw_buf)
# 開始加密
encrypt_buf=aes_obj.encrypt(padding_zero)
# 解密
buff=aes_obj.decrypt(encrypt_buf)

這個代碼中padding寫的還是非常漂亮的。如果在C里面實現這個,還需要啰嗦寫不少。

希望本文所述對大家Python程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: chinesemature精品 chinesefree普通对话 | 男女视频在线观看网站 | chinese特色video| 互换身体全集免费观看 | 四虎影视在线看 | 女人pp被扒开流水了 | 欧美精品一区二区三区免费观看 | 荡娃艳妇系列小说 | 人人九九| 日韩精品视频美在线精品视频 | 亚洲国产99999在线精品一区 | 日本性漫画 | 四虎4hu永久免费 | 日本在线精品视频 | 国产成人免费片在线视频观看 | 女烈受刑重口小说 | 出轨同学会免费观看 | 亚欧洲乱码视频一二三区 | 久草在线福利视频在线播放 | 色播艾小青国产专区在线播放 | 欧美一区高清 | 校花在公车上被内射好舒 | 久久er国产免费精品 | 亚洲国产成人精品激情 | 国产91第一页 | 日韩欧美国产一区 | 欧美高清一区 | 男人猛戳女人下部30分钟 | 免费在线电视 | fuqer日本| 美女脱小内内给男生摸j | 精品播放| 亚洲激情在线 | 干操网| 天若有情1992国语版完整版 | 99久久精品免费观看区一 | 欧美午夜视频一区二区三区 | 男同桌扒开女同桌胸罩喝奶 | 亚洲第一男人网站 | 瘦老汉gay | 成人欧美一区在线视频在线观看 |