python中内置hash模块hashlib

一、什么是hash

hash,是一种对数据进行变换的算法,这种算法有以下特点:
1.不定长输入,定长输出。
2.不能被还原。由于算法过程中丢弃了一些数据,但是丢弃的是什么,丢弃了多少,谁也不知道,所以无法被还原,有点类似于有损压缩,丢弃的不可能被找回。
3.相同输入,相同输出。
4.抗碰撞性。即碰撞(不同输入产生相同输出)的几率特别小。
5.抗篡改性。输入稍有改动,输出差别非常大。
因为hash算法的以上五个特点,所以它主要有以下几个用途:
1.数据结构(哈希表)。对于以键值对形式存储的数据,直接使用键地散列值作为存储地址,存储值。查找时就可以精准查找,不用遍历法一一比对那么麻烦。这是利用了hash的1,3,4特点。
2.密码储存。服务端现在都不存储用户名和密码了,直接存储它们的散列值,用户输入用户名和密码后也生成散列值,和数据库中的进行比对。这样即使数据被盗了 ,黑客也获取不了用户的密码。这是利用了hash的2,3,4,5特点。
3.文件签名。对文件签名,生成签名的散列值。在对方收到文件后对秘钥进行hash计算,看得到的散列值是否与签名相同。这是利用了hash的2,3,4,5特点。
4.文件校验。传输前后进行散列值的比较,同则文件没有损坏或篡改,不同则有损坏或篡改。比如有的网站为了禁止用户上传同样的视频,会对已上传的文件存储其散列值,通过比对新视频散列值是否已存在判断是否为重复上传的视频。如果你想上传相同视频,只要改掉一帧即可。这是利用了hash的2,3,4,5特点。

二、python中内置hash模块hashlib

hashlib模块提供了多种安全散列和消息摘要算法的公共接口。算法有sha1()、sha224()、sha256()、sha384()、sha512()和blake2b()、blake2s()。
hashlib用起来非常简单:

import hashlib
#第一步架锅
hs=hashlib.sha256()
#第二步放菜
hs.update(b'zhang')
#第三步出锅
hs_mg=hs.hexdigest()
print(hs_mg)

14bbfb46cb710ab5cf477269d856fc79d4d5b31cfbe466a37a43b1537e0693a4
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值