md5和sha算法经过消息摘要算法生成定长的消息摘要,消息摘要算法是不可逆的。但同一段消息经过摘要算法后获得的值是同样的,可一经过比对消息摘要验证数据的完整性。python
sha算法比MD5算法安全,但所需的时间也稍长。算法
一、原始消息摘要安全
import hashlib # ######## md5 ######## hash = hashlib.md5() hash.update('admin') print hash.hexdigest() #21232f297a57a5a743894a0e4a801fc3 # ######## sha1 ######## hash = hashlib.sha1() hash.update('admin') print hash.hexdigest(),len(hash.hexdigest()) # d033e22ae348aeb5660fc2140aec35850c4da997 40 # ######## sha256 ######## hash = hashlib.sha256() hash.update('admin') print hash.hexdigest(),len(hash.hexdigest()) # 8c6976e5b5410415bde908bd4dee15dfb167a9c873fc4bb8a81f6f2ab448a918 64 # ######## sha384 ######## hash = hashlib.sha384() hash.update('admin') print hash.hexdigest(),len(hash.hexdigest()) # 9ca694a90285c034432c9550421b7b9dbd5c0f4b6673f05f6dbce58052ba20e4248041956ee8c9a2ec9f10290cdc0782 96 # ######## sha512 ######## hash = hashlib.sha512() hash.update('admin') print hash.hexdigest(),len(hash.hexdigest()) # c7ad44cbad762a5da0a452f9e854fdc1e0e7a52a38015f23f3eab1d80b931dd472634dfac71cd34ebc35d16ab7fb8a90c81f975113d6c7538dc69dd8de9077ec 128
二、加盐(salt)后摘要分布式
因为同一个消息经过摘要算法获得的摘要是相同的,所以能够经过撞库的方式获得原始消息值。解决方式是,添加一个salt拼接原始消息后再进行计算。函数
import hashlib # ######## md5 ######## hash = hashlib.md5('898oaFs09f') hash.update('admin') print hash.hexdigest() #以上等价与 hash = hashlib.md5() hash.update('898oaFs09fadmin') print hash.hexdigest()
HAMC它内部对咱们建立 key 和 内容 再进行处理而后再加密,至关安全。通常用于挑战应答。ui
import hashlib import hmac h = hmac.new('keysstring') h.update('hello') print h.hexdigest(),len(h.hexdigest()) # 2ca7ac50a9bca542e58e0baad15f8383 32
UUID是128位的全局惟一标识符,一般由32字节的字符串表示。它能够保证时间和空间的惟一性,python中称为UUID,其余语言中可能称为GUID。
它经过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的惟一性。
UUID主要有五个算法,也就是五种方法来实现:
一、uuid1()——基于时间戳。由MAC地址、当前时间戳、随机数生成。能够保证全球范围内的惟一性,但MAC的使用同时带来安全性问题,局域网中可使用IP来代替MAC。
二、uuid2()——基于分布式计算。环境DCE(Python中没有这个函数)算法与uuid1相同,不一样的是把时间戳的前4位置换为POSIX的UID。实际中不多用到该方法。
三、uuid3()——基于名字的MD5散列值。经过计算名字和命名空间的MD5散列值获得,保证了同一命名空间中不一样名字的惟一性,和不一样命名空间的惟一性,但同一命名空间的同一名字生成相同的uuid。
四、uuid4()——基于随机数。由伪随机数获得,有必定的重复几率,该几率能够计算出来。
五、uuid5()——基于名字的SHA-1散列值。算法与uuid3相同,不一样的是使用 SHA-1算法。
python中没有实现uuid2算法。加密
import uuid print uuid.uuid1() print uuid.uuid3(uuid.NAMESPACE_DNS, 'testme') print uuid.uuid4() print uuid.uuid5(uuid.NAMESPACE_DNS, 'testme') # 1a52b39e-a197-11e6-b5c6-8056f2d4c814 # 7a67f5d4-50fd-36f7-bbeb-1c739ab40b8c # 0c0cc4f0-6ad0-40d3-a796-119dcfaddf60 # dac48d1f-a443-578c-8754-856842a2f98d