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