python之hmac库

python之hmac库

hmac库

hmac哈希加密库用到了对称加密
hmac模块提供了一个HMAC类和new函数。

hmac.new(加盐,需要加密的数据,加密的算法)
hmac.new(key,msg,digestmod)
key和digestmod参数必须指定,key和msg(需要加密的内容)均为bytes类型,digestmod指定加密算法,比如‘md5’,'sha1'等

如果消息很长,可以多次调用h.update(msg)

hexdigest()方法,返回十六进制哈希值
digest()方法,返回bytes类型哈希值

创建hash对象

返回加密哈希值

示例

message = b'Hello, world!'
key = b'secret'
# 创建hash对象,key和digestmod参数必须指定,key和msg(需要加密的内容)均为bytes类型,digestmod指定加密算法,比如‘md5’,'sha1'等
h = hmac.new(key, message, digestmod='MD5')
# 如果消息很长,可以多次调用h.update(msg)

print(h.hexdigest())    # hexdigest()方法,返回十六进制哈希值
# fa4ee7d173f2d97ee79022d1a7355bcf
print(h.digest())       # digest()方法,返回bytes类型哈希值
# b'\xfaN\xe7\xd1s\xf2\xd9~\xe7\x90"\xd1\xa75[\xcf'

# 其中的key是我们自己生成的,message是要加密的信息,如果消息太长,后续可以通过h.update(msg)来多次添加要加密的信息,加密模式默认为md5。
# 注意:key和message需要传入bytes类型的数据。

猜你喜欢

转载自blog.csdn.net/qq_44659804/article/details/128819563