python实现md5加密和解密(Python加密之md5和sha1加密)
python实现md5加密和解密(Python加密之md5和sha1加密)Python 内置的 hashlib 模块就包括了 md5 和 sha1 算法。而且使用起来也极为方便Python 中的用法:SHA1的全称是Secure Hash Algorithm(安全哈希算法) 。SHA1基于MD5,加密后的数据长度更长,它对长度小于264的输入,产生长度为160bit的散列值。比MD5多32位。因此,比MD5更加安全,但SHA1的运算速度就比MD5要慢了。
MD5
MD5的全称是Message-Digest Algorithm 5(信息-摘要算法)。128位长度。目前MD5是一种不可逆算法。
具有很高的安全性。它对应任何字符串都可以加密成一段唯一的固定长度的代码。
SHA1
SHA1的全称是Secure Hash Algorithm(安全哈希算法) 。SHA1基于MD5,加密后的数据长度更长,
它对长度小于264的输入,产生长度为160bit的散列值。比MD5多32位。
因此,比MD5更加安全,但SHA1的运算速度就比MD5要慢了。
Python 中的用法:
Python 内置的 hashlib 模块就包括了 md5 和 sha1 算法。而且使用起来也极为方便
MD5:
import hashlib
data = 'This a md5 test!'
hash_md5 = hashlib.md5(data)
hash_md5.hexdigest()
>>'0a2c0b988863f08471067903d8737962'
上面这段字符串就是 data 转换后的MD5值。
MD5不仅仅是上面这个例子这样用来处理字符串,还有更广泛的用途:
加密网站注册用户的密码。 (但去年的各大网站密码泄漏事件确实让人蛋疼……)
网站用户上传图片 / 文件后,计算出MD5值作为文件名。(MD5可以保证唯一性)
key-value数据库中使用MD5值作为key。
比较两个文件是否相同。(大家在下载一些资源的时候,就会发现网站提供了MD5值,就是用来检测文件是否被篡改)
sha1:
def get_str_sha1_secret_str(res:str):
import hashlib
sha = hashlib.sha1(res.encode('utf-8'))
encrypts = sha.hexdigest()
print(encrypts)
return encrypts
处理大文件:
上面说过可以用MD5来检测两个文件是否相同,但想想,如果是两个很大的文件,担心内存不够用,这时怎么办?
这就要使用 update 方法了。代码如下:
import hashlib
def get_file_md5(f):
m = hashlib.md5()
while True:
data = f.read(10240)
if not data:
break
m.update(data.encode("utf-8"))
return m.hexdigest()
with open(YOUR_FILE 'r') as f:
file_md5 = get_file_md5(f)
(windows 用户 要使用 'rb'方式打开文件)
方法亿:
import hashlib
from hashlib import md5
x = hashlib.md5()
x.update('hello'.encode("utf-8"))
x.update('python'.encode('utf-8'))
x.hexdigest()
方法二:
hashlib.md5('hellopython'.encode('utf-8')).hexdigest()
结果是一样的。
f.read()
read([size])方法从文件当前位置起读取size个字节,若无参数size,则表示读取至文件结束为止,它范围为字符串对象