在python3的标准库中,已经移除了md5,而关于hash加密算法都放在hashlib这个标准库中,如SHA1、SHA224、SHA256、SHA384、SHA512和MD5算法等。
MD5加密的方法:
方法一:
>>> import hashlib
>>> md = hashlib.md5()
>>> md.update(b'123456')
>>> md.hexdigest()
'e10adc3949ba59abbe56e057f20f883e'
方法二:
>>> hashlib.md5(b'123456').hexdigest()
'e10adc3949ba59abbe56e057f20f883e'
方法三:
>>> hashlib.new('md5', b'123456').hexdigest()
'e10adc3949ba59abbe56e057f20f883e'
如果要对中文进行加密,需要对字符进行转码:
看下面实例:
>>> obj0.update('中国'.encode('utf-8'))
>>> obj0.hexdigest()
'c13dceabcb143acd6c9298265d618a9f'
>>> hashlib.md5('中国'.encode('GBK')).hexdigest()
'cf0832dedf7457bbcbfa00bbd87b300a'
注释:
1. hashlib.new(name[, data])方法
这是个一般性方法。
name传入的是哈希加密算法的名称,如md5;
data传入的是需要加密的数据,可忽略,在之后update()中传入。
>>> md = hashlib.new('md5')
>>> md.update(b'123456')
>>> md.hexdigest()
'202cb962ac59075b964b07152d234b70'
2. hash.update(arg)
传入arg对象来更新hash的对象。必须注意的是,该方法只接受byte类型,否则会报错。这就是要在参数前添加b 来转换类型的原因:
>>> md = hashlib.md5()
>>> md.update('123456')
TypeError: Unicode-objects must be encoded before hashing
同时要注意,重复调用update()方法,是会将传入的数据进行拼接,md.update(a); md.update(b) 等价于md.update(a+b):
>>> md = hashlib.md5()
>>> md.update(b'123')
>>> md.hexdigest()
'202cb962ac59075b964b07152d234b70'
>>> md.update(b'456')
>>> md.hexdigest()
'e10adc3949ba59abbe56e057f20f883e'
>>> hashlib.md5(b'123456').hexdigest()
'e10adc3949ba59abbe56e057f20f883e'
3. hash.hexdigest()
此方法是将hash中的数据转换成数据,其中只包含十六进制的数字。另外还有hash.digest()方法。