python常用内建模块6 hmac

  • 我们可以验证一段数据是否有效,方法就是对比该数据的哈希值
  • 如果salt是我们自己随机生成的,通常我们计算MD5时采用md5(message + salt)。 但实际上把salt看作一个key,加salt的哈希就是:计算一段message的哈希时,根据不同口令计算出不同的哈希。
  • 要验证哈希值,必须同时提供正确的口令。
  • 这就是Hmac算法:Key-Hashing for Message Authentication。
  • 通过一个标准算法,在计算哈希的过程中,把key混入计算过程中。
  • 采用Hmac算法,可以使程序更标准化,也更安全化。
  • python自带的hmac模块实现了标准的Hmac算法。
  • 继续上篇的模拟登录
    import hmac,random
    
    def hmac_md5(key, s):  
    	return hmac.new(key.encode('utf-8'), s.encode('utf-8'), "MD5").hexdigest()
    
    class User(object):
    	def __init__(self, username, password):
    		self.username = username
    		self.key = ''.join([chr(random.randint(48,122)) for i in range(20)])   #产生key
    		self.password = hmac_md5(self.key, password)   #通过hmac_md5产生self用户的key加密口令
    
    db = {
    	'hewuxin': User('hewuxin','123456'),
    	'wuxin': User('wuxin','asd000')
    }				
    
    def login(username, password):
    	user = db[username]
    	return user.password == hmac_md5(user.key, password) 	#判断输入的password进过hmac_md5转换后是否和字典中的口令相同
    print(login('hewuxin','123456'))

     

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值