python os.urandom 安全_python 中md5 和 sha1 加密, md5 + os.urandom 生成全局唯一ID

首先先来介绍一下md5 和 sha1 的概念

MD5

MD5的全称是Message-Digest Algorithm 5(信息-摘要算法)。128位长度。目前MD5是一种不可逆算法。

具有很高的安全性。它对应任何字符串都可以加密成一段唯一的固定长度的代码。

SHA1

SHA1的全称是Secure Hash Algorithm(安全哈希算法) 。SHA1基于MD5,加密后的数据长度更长,

它对长度小于264的输入,产生长度为160bit的散列值。比MD5多32位。

因此,比MD5更加安全,但SHA1的运算速度就比MD5要慢了。

python 中使用md5 和 sha1

python 的内置模块hashlib 中自带了 md5, sha1 所以在python 使用这两种加密还是非常方便的。

md5 使用例子:

1 from hashlib importmd52 data_str = "hello world"

3 hash_md5 =md5(data_str).hexdigest()4 print hash_md5

结果为:5eb63bbbe01eeed093cb22bb8f5acdc3

sha1 使用例子:

1 from hashlib importsha12 data_str = "hello world"

3 hash_sha1 =sha1(data_str).hexdigest()4 print hash_sha1

结果为:2aae6c35c94fcfb415dbe95f408b9ce91ee846ed

可以看到的是,相同的字符串,加密后sha1的结果要比md5的结果在长度上要长一些。形同字符串,相同加密算法产生的加密串是相同的。

他们不仅可以用来加密字符串使用,往往还可以用来当做文件名,当做key value 格式存储的key,运行任务产生的instance id 等。

使用md5 + os.urandom(n) 产生随机字符串

有点时候我们会需要产生一个全局唯一的id,这个时候,md5 + os.urandom 就派上用场了。

os.urandom(n) 是一种随机生成n个字节字符串的方法,而且每次生成的值都不相同。再加上md5的处理,就能够成内容不同长度相同的字符串了。

例子:

importosfrom hashlib importmd5for i in range(10):print md5(os.urandom(24)).hexdigest()

输出结果:

3c0919ae5c84adc230a7adbb90446913

569c086e2f8badaf64065978ccb58482

3fa55d4a2a0de854bac9d33c730b7424

91b4a5029980a8166e305fe7d785b5d7

b251e79ec54c7f0320bb41320b8c6033

79c78471e6d87ba7dc11cb40618b2cf8

c14a40bb41e2ce4311d27b1add3af843

148340f61bd2193fa9fa1151f7ba7159

f3d2084ee4df18e6ad03a13ac6857f47

2f027d38265ec0576edb0c1d24eb6f68

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值