博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hash文件校验
阅读量:3961 次
发布时间:2019-05-24

本文共 1254 字,大约阅读时间需要 4 分钟。

import hashlibimport os"""mode => r  read(数字->字符个数)mode => rb read(数字->字节个数)字节的个数 <=> 文件的大小"""

(1) 针对于小文件进行内容校验

def check_md5(filename):	hs = hashlib.md5()	with open(filename,mode="rb") as fp:					hs.update(fp.read())	return hs.hexdigest()	res1 = check_md5("ceshi1.txt")res2 = check_md5("ceshi2.txt")print(res1,res2)

(2) 针对于大文件进行内容校验

# 可以通过update 把字符串分段进行加密# 常规方法strvar = "今天是星期五,好开心了,下周一又要考试了."hm = hashlib.md5()hm.update(strvar.encode())res = hm.hexdigest()print(res)

分段更新加密

hm = hashlib.md5()hm.update("今天是星期五,好开心了,".encode())hm.update("下周一又要考试了.".encode())res = hm.hexdigest()print(res)# 方法一def check_md5(filename):	hs = hashlib.md5()	with open(filename,mode="rb") as fp:		while True:			content = fp.read(10) # 一次最多读取10个字节			if content:				# 分批进行字符串密码更新				hs.update(content)			else:				break		return hs.hexdigest()	res1 = check_md5("ceshi1.txt")res2 = check_md5("ceshi2.txt")print(res1,res2)

# 方法二def check_md5(filename):	hs = hashlib.md5()	# 计算文件大小=>返回字节数	filesize = os.path.getsize(filename)	with open(filename,mode="rb") as fp:		while filesize:			content = fp.read(10) # 一次最多读取10个字节			hs.update(content)			# 按照实际的字节个数读取			filesize -= len(content)		return hs.hexdigest()	res1 = check_md5("ceshi1.txt")res2 = check_md5("ceshi2.txt")print(res1,res2)

转载地址:http://cwhzi.baihongyu.com/

你可能感兴趣的文章
docker下删除none的images
查看>>
Linux提权获取敏感信息方法
查看>>
Ubuntu 16.04开机A start job is running for Raise network interface(5min 4s)解决方法
查看>>
Ubuntu 16.04开机隐藏菜单缩短时间
查看>>
Ubuntu 更换国内源
查看>>
Ubuntu16.04下Docker pull connection refused 解决办法
查看>>
通过 三大机制 揭秘 IPFS 工作原理
查看>>
Ubuntu 16.04卸载PostgresQL
查看>>
华为路由器交换机配置命令
查看>>
docker下运行kalilinux并配置ssh访问
查看>>
使用 Docker 容器应该避免的 10 个事情
查看>>
postgres基本操作(个人总结版)
查看>>
求数组中最长递增子序列
查看>>
用C++设计一个不能被继承的类
查看>>
linux core文件机制
查看>>
私有继承中的派生类对象与基类对象间的转换
查看>>
5.7 观察者模式observer(行为模式)
查看>>
建造者模式Builder(创建模式)
查看>>
Linux文件系统目录结构的详细解说(一)
查看>>
TIME_WAIT状态的意义
查看>>