江湖道

庙堂,江湖,学术!

返回顶部

Python之模块分类(五)

一、hashlib模块

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

#Author:Anliu
import hashlib

m = hashlib.md5()
m.update(b"hello")
print(m.hexdigest())
m.update(b"world")
print(m.hexdigest())
#print(m.digest())
m1 =hashlib.md5()
m1.update(b"helloworld")
print(m.hexdigest())
# 同一个对象的加密是累加的
#print(m.digest())  #二进制的方式加密
#print(m.hexdigest())  #十六进制的方式加密

m2 = hashlib.md5()
m2.update("大中国".encode(encoding="utf-8"))
print(m2.hexdigest())

#带有中文的字符串要encode为bytes
# ######## md5 ########

hash = hashlib.md5()
hash.update('admin')
print(hash.hexdigest())

# ######## 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 模块

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

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

#Author:Anliu
import hmac
h = hmac.new("好好学习".encode(encoding="utf-8"))
print(h.hexdigest())
posted @ 2020-04-16 17:35  大江东流水  阅读(198)  评论(0编辑  收藏  举报