用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
import hashlib
m = hashlib.md5() # m=hashlib.sha256()
m.update( 'hello' .encode( 'utf8' ))
print (m.hexdigest()) #5d41402abc4b2a76b9719d911017c592
m.update( 'alvin' .encode( 'utf8' ))
print (m.hexdigest()) #92a7e713c30abbb0319fa07da2a5c4af
m2 = hashlib.md5()
m2.update( 'helloalvin' .encode( 'utf8' ))
print (m2.hexdigest()) #92a7e713c30abbb0319fa07da2a5c4af
|
以上加密算法虽然依然非常厉害,但时候存在缺陷,即:通过撞库可以反解。所以,有必要对加密算法中添加自定义key再来做加密。
1 2 3 4 5 6 7 |
import hashlib
# ######## 256 ########
hash = hashlib.sha256( '898oaFs09f' .encode( 'utf8' ))
hash .update( 'alvin' .encode( 'utf8' ))
print ( hash .hexdigest()) #e79e68f070cdedcfe63eaf1a2e92c83b4cfb1b5c6bc452d214c1b7e77cdfd1c7
|
python 还有一个 hmac 模块,它内部对我们创建 key 和 内容 再进行处理然后再加密:
1 2 3 4 |
import hmac
h = hmac.new( 'alvin' .encode( 'utf8' ))
h.update( 'hello' .encode( 'utf8' ))
print (h.hexdigest()) #320df9832eab4c038b6c1d7ed73a5940
|
1