标签:文件的 长度 col 作用 enc python date 检验 而且
什么是摘要算法呢?摘要算法又称哈希算法、散列算法。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用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 安全 越长越慢
标签:文件的 长度 col 作用 enc python date 检验 而且
原文地址:https://www.cnblogs.com/LMTlmt/p/10284279.html