小白的Python之路 day5 hashlib模块

时间:2023-03-08 16:54:17
小白的Python之路 day5 hashlib模块

hashlib模块

一、概述

用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法

二、算法的演示

下面就以MD5为大家演示一下加密:

import hashlib

m = hashlib.md5()  #创建MD5对象m
m.update(b"qian")    #在python3中需要是2进制的值,所以字符串前加b
print(m.digest())     #以2进制打印MD5值
print(m.hexdigest())  #以16进制打印MD5值
#输出
b'a\xcbr\x85\x8b\xe5#\xb9\x92n\xcc=}\xa5\xd0\xc6'
61cb72858be523b9926ecc3d7da5d0c6

m.update(b"duoduo")
print(m.hexdigest())
#输出
d1f9c121f6b9e984c1b6a2b77443871f

m2 = hashlib.md5()    #创建MD5对象m2
m2.update(b"qianduoduo")
print(m2.hexdigest())
#输出
d1f9c121f6b9e984c1b6a2b77443871f

重点:

SHA1, SHA224, SHA256, SHA384, SHA512 这几种安全等级比MD5更高,加密的方法也是一样的,进行hashlib模块调用,就可以对字符串对象进行加密.

但是加密等级越高效率就越低.

如果加密中文的话,要声明一下字符编码

3、hmac加密

还不够吊?python 还有一个 hmac 模块,它内部对我们创建 key 和 内容 再进行处理然后再加密

散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;

一般用于网络通信中消息加密,前提是双方先要约定好key,就像接头暗号一样,然后消息发送把用key把消息加密,接收方用key + 消息明文再加密,拿加密后的值 跟 发送者的相对比是否相等,这样就能验证消息的真实性,及发送者的合法性了。

1
2
3
import hmac
= hmac.new(b'天王盖地虎', '宝塔镇河妖'.encode(encoding="utf-8"))
print h.hexdigest()      

更多关于md5,sha1,sha256等介绍的文章看这里https://www.tbs-certificates.co.uk/FAQ/en/sha256.html