#加密模块 hashlib
# 1.将一个bysts类型的数据, 通过hashlib进行一个加密返回 一个等长度的16进制数字
# 2.过程不可逆
# 3.相同的bysts类型的数据通过相同的加密方法得到的数字绝对相同
# 4.不相同的bysts类型的数据通过相同的加密方法得到的数字绝对不同
#用于密码加密
#md5系列安全系数低 效率高 3步
import hashlib
ret=hashlib.md5() # 第一步 生成一个对象
ret.update("12fafasf3".encode("utf8")) # 第二步 把传入的数据的二进制形式传到对象中
print(ret.hexdigest()) # 第三步 以字符串形式返回密文
#这种方式加密 通过撞库 已经被破解啦 不安全
#加固定盐 或加动态的盐 来提高安全性 没有被破解
username=input("请输入用户名:").strip()
#ret=hashlib.md5("xx教育".encode("utf8")) #加静态盐 安全系数高
ret=hashlib.md5(username.encode("utf8")) #加动态盐
ret.update("12fafasf3".encode("utf8"))
print(ret.hexdigest())#以字符串形式返回密文
#sha系列 安全系数高 耗时间长
ret=hashlib.sha512() #也可以加盐 跟上面一样
ret.update("12fafasffsadfasfsaf3".encode("utf8"))
print(ret.hexdigest())#以字符串形式返回密文
# 文件一致性校验 就是把文件内容用hashlib生成一个密文,把下载前后的密文进行对比,判断有无变化
#low版 比较md5值
ret=hashlib.md5()
with open("文件校验",mode="rb")as f1:
content=f1.read(1024) # rb 模式每次至多读1024个字节 r模式每次至多读1024个字符
#content1 = f1.read(1024)接着往下读
ret.update(content)
print(ret.hexdigest())
#文件过大分步校验
import hashlib
def md5_file(path):
ret=hashlib.md5()
with open(path, mode="rb")as f1:
while 1:
content=f1.read(1024)
if content:
ret.update(content)#放到容器中 可以多次放置
else:
return ret.hexdigest()
print(md5_file(r"C:\Users\anrui\Desktop\面试\1.txt"))
#小练习1:
# 写函数,让用户输入用户名密码,将密码转化为密文,然后构建一个字典,字典的键为用户名,值为密码 用json 存到文件中
import hashlib
import json
username=input("请输入您的账号:")
password=input("请输入您的密码:")
ret=hashlib.md5("anrui".encode("utf8"))
ret.update(password.encode("utf8"))
content=ret.hexdigest()
dic={"username":username,"password":content}
with open("测试",encoding="utf8",mode="a")as f1:
json.dump(dic,f1,ensure_ascii=False)
with open("测试",encoding="utf8",mode="r")as f1:
res=json.load(f1)
print(res)
|