Python3入门(十三)——常用内置模块之摘要模块hashlib/hmac

本文详细介绍了Python中hashlib模块的使用,包括常见摘要算法如MD5、SHA1等,并通过示例展示了如何使用这些算法进行数据加密。此外,还深入探讨了HMAC算法,解释了如何通过增加salt来提高哈希安全性,防止黑客攻击。

(1)hashlib

hashlib提供了常见摘要算法:如MD5,SHA1等等

一个md5的加密示例如下:

import hashlib

m = hashlib.md5()
m.update("hello python".encode("utf-8"))
print(m.hexdigest())

更多示例,参考如下:

  https://blog.youkuaiyun.com/qq_31726841/article/details/82464990

(2)hmac

为了防止黑客通过彩虹表根据哈希值反推原始口令,在计算哈希的时候,不能仅针对原始输入计算,需要增加一个salt来使得相同的输入也能得到不同的哈希,这样,大大增加了黑客破解的难度。

如果salt是我们自己随机生成的,通常我们计算MD5时采用md5(message + salt)。但实际上,把salt看做一个“口令”,加salt的哈希就是:计算一段message的哈希时,根据不通口令计算出不同的哈希。要验证哈希值,必须同时提供正确的口令。

这实际上就是Hmac算法:Keyed-Hashing for Message Authentication。它通过一个标准算法,在计算哈希的过程中,把key混入计算过程中。

 

示例代码如下:

import hmac

key = "se".encode("utf-8")
msg = "hello python".encode("utf-8")
h = hmac.new(key, msg, digestmod="md5")
print(h.hexdigest())

 

转载于:https://www.cnblogs.com/jiangbei/p/10996503.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值