各位用户为了找寻关于Python AES加密模块用法分析的资料费劲了很多周折。这里教程网为您整理了关于Python AES加密模块用法分析的相关资料,仅供查阅,以下为您介绍关于Python 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 24from
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程序设计有所帮助。