本文实例讲述了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程序设计有所帮助。