message = b'Hello, world!'
key = b'secret'
h = hmac.new(key, message, digestmod='MD5')
# 如果消息很长,可以多次调用h.update(msg)
print h.hexdigest()
其中的key是我们自己生成的,message是要加密的信息,如果消息太长,后续可以通过h.update(msg)来多次添加要加密的信息,加密模式默认为md5。
注意:key和message需要传入bytes类型的数据。
import hashlib
import hmac
message='hello world父老乡亲大家好'
digest_maker = hmac.new('JnegwefNweN4NG'.encode='utf-8', message.encode('utf-8', hashlib.sha1)
# 再传入一个要加密的信息
digest_maker.update('大叔大妈过年好')
digest = digest_maker.digest() # 返回摘要信息,默认返回是字节类型,根据需要自己转化
# 这里转化为base64类型,需要import base64
import base64
base64.encoddbytes(digest).decode('utf-8')