hashlib

  什么是摘要算法呢?摘要算法又称哈希算法、散列算法。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。

摘要算法就是通过摘要函数f()对任意长度的数据data计算出固定长度的摘要digest,目的是为了发现原始数据是否被人篡改过。

摘要算法之所以能指出数据是否被篡改过,就是因为摘要函数是一个单向函数,计算f(data)很容易,但通过digest反推data却非常困难。而且,对原始数据做一个bit的修改,都会导致计算出的摘要完全不同。

作用是 

 加密
文件下载的时候,同过生成的哈希值来检验文件的一致性

下面给出MD5,SHA1 俩种写法    

MD5

mport hashlib
 
md5 = hashlib.md5()
md5.update('how'.encode('utf-8'))
print(md5.hexdigest())
 
结果:db88a0257c220dbfdd2e40f6152d6a8d

import hashlib
# md5 = hashlib.md5('alex'.encode('utf-8'))
# #加盐
# md5.update('你好啊'.encode('utf-8'))
# print(md5.hexdigest())

 

 

SHA1  

HA1的结果是160 bit字节,通常用一个40位的16进制字符串表示。

SHA1的安全系数比MD5还要高一些,而且摘要的长度要比MD5长一些.

比SHA1更安全的算法是SHA256和SHA512,不过越安全的算法越慢,而且摘要长度更长。

import hashlib
 
sha1 = hashlib.sha1()
sha1.update('how to use sha1 in'.encode('utf-8'))
sha1.update('python hashlib?'.encode('utf-8'))
print(sha1.hexdigest())
 
结果:86e1eae2a08c152d39b55baed085c71a0cc9d10b
import hashlib
s1 = hashlib.sha1('a'.encode('utf-8'))#加盐
s1.update('你哈'.encode('utf-8'))
print(s1.hexdigest())
c9dbe3cd4bc5844de1d30403d98eeeec6008bcb2
7e81cf96d8605215ad366063cd2abf7c6726018b
安全   越长越慢 

 

posted @ 2019-01-17 20:02  LmtMe  阅读(129)  评论(0编辑  收藏  举报