python AES加密模組使用
阿新 • • 發佈:2019-02-02
AES是新的一種加密模組。在上次介紹過在C語言中如何來OpenSSL中的DES。這次我們來看看python自帶的庫如何來使用AES來加解密。其實二者的原理還是非常像,只是說在python中來做這個事情會比C語言要簡單點,但是比起C#/JAVA還是有點點囉嗦。在C#/JAVA這種語言中,對於加密的源資料的處理,padding一般都會有完整的實現。我在上次C語言中也處理過這個問題。在python庫中,也是需要自己來處理這個。
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裡面實現這個,還需要囉嗦寫不少。