#加密模块 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)
python-加密和文件校验使用到的hashlib模块
最新推荐文章于 2024-05-08 15:38:44 发布