PHP前端开发

hashlib模块之加密的介绍

百变鹏仔 3小时前 #Python
文章标签 模块

用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 sha1, sha224, sha256, sha384, sha512 ,md5 算法

import hashlibm = hashlib.md5()m.update(b"hello")print(m.hexdigest())m.update(b"It's me")print(m.hexdigest())m.update(b"It's been a long time since we spoken.")print(m.hexdigest())m2 = hashlib.md5()m2.update(b"helloIt's me")print(m2.hexdigest())# 输出5d41402abc4b2a76b9719d911017c59264f69d95135bc13d4827f871b37f780f0c9a83e10aa2f9e9629be61146db9cc264f69d95135bc13d4827f871b37f780f#第二个和第四个 md5值是相同的,所以第二个加密的是 helloIt'sme

print(m.digest()) #2进制格式hash

print(len(m.hexdigest())) #16进制格式hash
 
# ######## 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())

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

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

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

import hmach = hmac.new("天王盖地虎".encode(encoding="utf-8"), "你是小松鼠".encode(encoding="utf-8"))print(h.digest())print(h.hexdigest())#输出b'fx�ݞ��cQN�c�ـ-'6678addd9ed6dd63514e8263cdd9802d