Python 中 MD5 哈希函数的实现

什么是MD5?
Python中的MD5哈希
与md5相关的功能
示例1:在Python中打印等效于MD5哈希的字节
示例2:在Python中打印MD5哈希的十六进制等效项
示例3:Python MD5文件校验输出与说明
示例4:使用Python在MD5中编码字符串输出与说明
示例5:在Python中计算文件的MD5哈希输出与说明
应用范围
优点
缺点
结论
hashlib模块中可用。它以字节序列作为输入,并返回128位哈希值作为输出。散列函数的主要用途是检查数据完整性,但存在安全性问题。encode():将字符串转换为字节digest(): 以字节格式返回编码数据hexdigest():以十六进制格式返回编码的数据
import hashlib 
 
result = hashlib.md5(b'Python Pool') 
print("Hash Value : ", end ="")
print(result)
print("Equivalent Byte : ", end ="") 
print(result.digest()) 

digest()函数生成了编码字符串的等效字节。import hashlib 
 
result = hashlib.md5('Python Pool'.encode()) 
print("Hash Value : ", end ="")
print(result)
print("Hexadecimal Equivalent : ", end ="") 
print(result.hexdigest()) 

encode()函数将字符串转换为等效的字节,从而使其被哈希函数接受。然后,我们使用md5函数对其进行编码,最后,使用hexdigest()函数显示其十六进制等效项。md5_hash = hashlib.md5()
 
file = open("test.txt", "rb")
content = file.read()
md5_hash.update(content)
 
result = md5_hash.hexdigest()
print(result)

hashlib.md5()函数以创建MD5对象。我们以“ rb”模式打开了一个文件,其中rb代表“ read bytes”。使用read()方法,我们将文件的内容读取到一个变量中。update()方法更新文件内容。最后,使用hexdigest()方法,我们将哈希值转换为等效的十六进制值。import hashlib 
string = "pythonpool.com"
encoded=string.encode()
result = hashlib.md5(encoded)
print("String : ", end ="")
print(string)
print("Hash Value : ", end ="")
print(result)
print("Hexadecimal equivalent: ",result.hexdigest())

hashlib.md5()函数将字符串值编码为哈希值。然后,我们使用hexdigest()方法来获取生成的哈希值的十六进制等效项。同样,我们也可以使用digest()方法来获取与生成的哈希值等效的字节。import hashlib
 
with open("sample.txt","rb") as f:
    bytes = f.read()
    print("Bytes read from the file:",bytes)
    result = hashlib.md5(bytes)
    print("Hah Value: ",result)
    print("The hexadecimal equivalent: ")
    print(result.hexdigest())

在软件中使用,以确保传输的文件完整无缺 通过为在法律发现过程中交换的每个文档提供唯一的标识符,它也可用于电子发现(对可能涉及到诉讼相关的电子证据的归档和再现) 
提供一个任意大小的安全输入(如果使用128位,则可以产生输出) 原始消息的消息摘要的生成非常简单 可以执行具有任意位数的消息的消息摘要 
容易出现哈希冲突的弱点 没有提供针对这些碰撞攻击的安全性 与优化的SHA算法相比,速度相当慢 
更多阅读
特别推荐

点击下方阅读原文加入社区会员
评论
