AES是新的一種加密模塊。在上次介紹過在C語言中如何來OpenSSL中的DES。這次我們來看看Python自帶的庫如何來使用AES來加解密。其實二者的原理還是非常像,只是說在python中來做這個事情會比C語言要簡單點,但是比起C#/Java還是有點點啰嗦。在C#/JAVA這種語言中,對于加密的源數(shù)據(jù)的處理,padding一般都會有完整的實現(xiàn)。我在上次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) # 做字節(jié)對齊 padding_zero=pad(raw_buf) # 開始加密 encrypt_buf=aes_obj.encrypt(padding_zero) # 解密 buff=aes_obj.decrypt(encrypt_buf)