Python之hashlib模块
用hashlib的md5算法加密数据
import hashlib hash = hashlib.md5()#md5对象 hash.update(bytes('admin',encoding='utf-8'))#对字符串进行加密 print(hash.hexdigest())#拿到加密字符串 # hash2=hashlib.sha384()#不同算法,hashlib很多加密算法 # hash2.update(bytes('admin',encoding='utf-8')) # print(hash.hexdigest()) hash3 = hashlib.md5(bytes('abd',encoding='utf-8')) ''' 如果没有参数,所以md5遵守一个规则,生成同一个对应关系,如果加了参数, 就是在原先加密的基础上再加密一层,这样的话参数只有自己知道,防止被撞库, 因为别人永远拿不到这个参数 ''' hash3.update(bytes('admin',encoding='utf-8')) print(hash3.hexdigest())
SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。
例子:文件md5校验
def md5(fileMd5): import hashlib md5_value = hashlib.md5() with open(fileMd5,'rb') as f: while True: #每次读取2048个字节数据 data = f.read(2048) if not data: break #计算md5值 md5_value.update(data) return md5_value.hexdigest()
关于hashlib其他加密算法
# ######## sha1 ######## hash = hashlib.sha1() hash.update('admin') print(hash.hexdigest()) # ######## sha256 ######## hash = hashlib.sha256() hash.update('admin') print(hash.hexdigest()) # ######## sha384 ######## hash = hashlib.sha384() hash.update('admin') print(hash.hexdigest()) # ######## sha512 ######## hash = hashlib.sha512() hash.update('admin') print(hash.hexdigest())
HMAC模块
python 还有一个 hmac 模块,它内部对我们创建 key 和 内容 再进行处理然后再加密
散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;
一般用于网络通信中消息加密,前提是双方先要约定好key,就像接头暗号一样,然后消息发送把用key把消息加密,接收方用key + 消息明文再加密,拿加密后的值 跟 发送者的相对比是否相等,这样就能验证消息的真实性,及发送者的合法性了。
import hmac h = hmac.new("天王盖地虎".encode(encoding="utf-8"), "你是小松鼠".encode(encoding="utf-8")) print(h.digest()) print(h.hexdigest()) #输出 b'fx\xad\xdd\x9e\xd6\xddcQN\x82c\xcd\xd9\x80-' 6678addd9ed6dd63514e8263cdd9802d

更多精彩