本文實例講述了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程序設計有所幫助。