用于加密相关的操作,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 |