Python3 hashlib模块和hmac 模块(加密)
hashlib 是一个提供了一些流行的hash算法的 Python 标准库.其中所包括的算法有 md5, sha1, sha224, sha256, sha384, sha512等常用算法
MD5加密算法
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
import hashlib""" MD5加密 """hash_md5 = hashlib.md5()hash_md5.update(b"hello")#b 表示byte类型hash_md5.update(b"world")print(hash_md5.hexdigest())""" 十六进制MD5加密结果"""print(hash_md5.digest())""" 二进制MD5加密结果 """""" 分几次update的参数加密结果和拼接一起加密结果一样"""hashmd5 = hashlib.md5()hashmd5.update(b"helloworld")print(hashmd5.hexdigest())print(hashmd5.digest()) |
运行结果:
|
1
2
3
4
|
fc5e038d38a57032085441e7fe7010b0 --十六进制b'\xfc^\x03\x8d8\xa5p2\x08TA\xe7\xfep\x10\xb0' --二进制fc5e038d38a57032085441e7fe7010b0b'\xfc^\x03\x8d8\xa5p2\x08TA\xe7\xfep\x10\xb0' |
SHA加密算发,常用256的,位数越长越安全
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
import hashlibprint("hash1加密的二进制和十六进制结果")hash1 = hashlib.sha1()hash1.update(b"helloworld")print(hash1.digest())print(hash1.hexdigest())print("hash256加密的二进制和十六进制结果")hash256 = hashlib.sha256()hash256.update(b"helloworld")print(hash256.digest())print(hash256.hexdigest())print("hash384加密的二进制和十六进制结果")hash384 = hashlib.sha384()hash384.update(b"helloworld")print(hash384.digest())print(hash384.hexdigest())print("hash512加密的二进制和十六进制结果")hash512 = hashlib.sha512()hash512.update(b"helloworld")print(hash512.digest())print(hash512.hexdigest()) |
运行结果:
|
1
2
3
4
5
6
7
8
9
10
11
12
|
hash1加密的二进制和十六进制结果b'j\xdf\xb1\x83\xa4\xa2\xc9J/\x92\xda\xb5\xad\xe7b\xa4x\x89\xa5\xa1'6adfb183a4a2c94a2f92dab5ade762a47889a5a1hash256加密的二进制和十六进制结果b'\x93j\x18\\\xaa\xa2f\xbb\x9c\xbe\x98\x1e\x9e\x05\xcbx\xcds+\x0b2\x80\xeb\x94D\x12\xbbo\x8f\x8f\x07\xaf'936a185caaa266bb9cbe981e9e05cb78cd732b0b3280eb944412bb6f8f8f07afhash384加密的二进制和十六进制结果b"\x97\x98*[\x14\x14\xb9\x07\x81\x03\xa1\xc0\x08\xc4\xe3Rl'\xb4\x1c\xdb\xcf\x80y\x05`\xa4\x0f*\x9b\xf2\xedD'\xab\x14(x\x99\x15\xedK=\xc0|EK\xd9"97982a5b1414b9078103a1c008c4e3526c27b41cdbcf80790560a40f2a9bf2ed4427ab1428789915ed4b3dc07c454bd9hash512加密的二进制和十六进制结果b'\x15\x94$MR\xf2\xd8\xc1+\x14+\xb6\x1fG\xbc.\xafP=m\x9c\xa8H\x0c\xae\x9f\xcf\x11/f\xe4\x96}\xc5\xe8\xfa\x98(^6\xdb\x8a\xf1\xb8\xff\xa8\xb8L\xb1^\x0f\xbc\xf86\xc3\xde\xb8\x03\xc1?7e\x9a`'1594244d52f2d8c12b142bb61f47bc2eaf503d6d9ca8480cae9fcf112f66e4967dc5e8fa98285e36db8af1b8ffa8b84cb15e0fbcf836c3deb803c13f37659a60 |
中文的加密,需要编码encode()得到bytes类型,再进行加密操作
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import hashlibprint("===MD5中文加密举例===")china_md5 = hashlib.md5()china_md5.update("中华人民共和国".encode(encoding="utf-8"))print(china_md5.digest())print(china_md5.hexdigest())print("===SHA中文加密举例===")china_sha = hashlib.sha256()china_sha.update("中华人民共和国".encode(encoding="utf-8"))print(china_sha.digest())print(china_sha.hexdigest()) |
运行结果:
|
1
2
3
4
5
6
|
===MD5中文加密举例===b'\x02_\xce\xab\x94\x18\xbe\x86\x06k`\xa7\x1b\xc7\x14\x85'025fceab9418be86066b60a71bc71485===SHA中文加密举例===b'\xcak\x1e6\x84\xd5\xaa\xeec1\x90\xb1\x82\xce\xbb\x06\xd6%\xd2\x84\xfe\xc8\x9a\x95\x15 -v\xf4\xd6J?'ca6b1e3684d5aaee633190b182cebb06d625d284fec89a9515202d76f4d64a3f |
hmac 模块,它内部对我们创建 key 和 vlaue 再进行处理然后再加密
散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;
一般用于网络通信中消息加密,前提是双方先要约定好key,就像接头暗号一样,然后消息发送把用key把消息加密,接收方用key + 消息明文再加密,拿加密后的值 跟 发送者的相对比是否相等,这样就能验证消息的真实性,及发送者的合法性了。
hmac加密示例
|
1
2
3
4
5
6
7
8
9
10
11
|
import hmacprint("===hmac字符加密示例===")hm = hmac.new(b"hello",b"world")print("hmac二进制加密:",hm.digest())print("hmac十六进制加密:",hm.hexdigest())print("===hmac中文加密示例===")ch = hmac.new("你好".encode(encoding="utf-8"),"世界".encode(encoding="utf-8"))print("hmac二进制加密:",ch.digest())print("hmac十六进制加密:",ch.hexdigest()) |
运行结果:
|
1
2
3
4
5
6
|
===hmac字符加密示例===hmac二进制加密: b'\x0e%d\xb7\xe1\x00\xf044\x1e\xa4w\xc2?(;'hmac十六进制加密: 0e2564b7e100f034341ea477c23f283b===hmac中文加密示例===hmac二进制加密: b'\xb0\x90\xbdU\xda:\xe1\xef\xa9fts@\xbf%\n'hmac十六进制加密: b090bd55da3ae1efa966747340bf250a |

浙公网安备 33010602011771号