hashlib 模块(hash)算法

hashlib 模块是 Python 中用于加密散列(hash)算法的模块。它提供了对常见的哈希算法(如MD5、SHA-1、SHA-256等)的支持,使得开发者可以轻松地在其应用中进行数据的安全散列。

以下是 hashlib 模块中一些常用的哈希算法:

  1. MD5 (Message Digest Algorithm 5): 产生128位的哈希值,通常以32位十六进制数字表示。

  2. SHA-1 (Secure Hash Algorithm 1): 产生160位的哈希值,通常以40位十六进制数字表示。然而,由于SHA-1存在一些弱点,推荐使用更安全的算法。

  3. SHA-224, SHA-256, SHA-384, SHA-512: SHA-2 系列,分别产生224、256、384和512位的哈希值。

md5算法:

我们使用 .md5() 创建了一个 MD5 哈希对象,然后使用 .update() 方法更新了输入数据,最后使用 .hexdigest() 方法获取了最终的 MD5 哈希值。

import hashlib

# 创建MD5对象
obj = hashlib.md5()
# 把要加密的信息传递给obj
obj.update("666666".encode("utf-8"))
# 从obj中拿到密文
mi = obj.hexdigest()
print(mi) #运行结果
f379eaf3c831b04de153469d1bec345e

这里注意:update要求,我们给定的字符串需要先被编码encode("utf-8"),再进行哈希

obj.update("666666")

#运行结果
obj.update("666666")
TypeError: Strings must be encoded before hashing

MD5哈希函数算法是单向的,也就是用拿到的密码是无法反向解密的。因此,通常存储密码时,都是存储其哈希值而不是明文密码。

但是因为MD5的算法已经存在很多年了,现在很多网站上都有MD5的撞库查询法:

这是我们拿加密好的值f379eaf3c831b04de153469d1bec345e来查询为666666的结果

如果一个网站仍然使用MD5来存储密码,这是一种不安全的做法,因为攻击者可以使用预先计算好的MD5散列(称为彩虹表)或现代碰撞攻击技术来破解密码。现代的密码存储做法通常包括使用“盐”(salt)和强大的哈希算法,以增加密码的安全性。

解决撞库的方法:加盐(salt)

加盐的基本思想是在计算哈希值之前,将一个随机生成的字符串与用户密码组合在一起。这个随机字符串就是“盐”(salt),每个用户都有一个唯一的盐值。通过在密码和盐的基础上计算哈希,可以避免使用相同密码的用户在哈希值上产生相同的模式。

加盐操作是一种提高密码安全性的常见做法,可以用于任何哈希算法。无论是MD5、SHA-1、SHA-256,还是其他更安全的哈希算法,都可以通过加盐操作来增加密码的复杂性,提高安全性。

盐必须是bytes类型,这里我们随便输入一个盐b'jkklwajdkljilasd'

obj = hashlib.md5(b'jkklwajdkljilasd')
obj.update("666666".encode("utf-8"))
print(obj.hexdigest()) #运行结果
f96b5f9f131ff8f0d7277b02cd243cc5

使用密码做盐,进行md5加密

def func(salt, s):
obj = hashlib.md5(salt)
obj.update(s.encode("utf-8"))
return obj.hexdigest() username = input("请输入你的用户名")
password = input("请输入你的密码")
mi_password = func(password.encode("utf-8"), password)
with open("user.txt", mode="w", encoding="utf-8") as f:
f.write(username)
f.write("\n")
f.write(mi_password) #运行结果,生成user.txt文档:
admin
bc177a7a9c7df69c248647b4dfc6fd84

使用动态盐,进行hash加密

def func(salt, s):
obj = hashlib.md5(salt)
obj.update(s.encode("utf-8"))
return obj.hexdigest() username = input("请输入你的用户名")
password = input("请输入你的密码")
mi_password = func(password.encode("utf-8"), password)
with open("user.txt", mode="w", encoding="utf-8") as f:
f.write(username)
f.write("\n")
f.write(mi_password) # 登录验证
username = input("用户名:")
password = input("密码:")
password = func(password.encode("utf-8"), password) with open("user.txt", mode="r", encoding="utf-8") as f:
uname = f.readline().strip()
upassword = f.readline().strip() if username == uname and password == upassword:
print("登录成功")
else:
print("登录失败")

在实际应用中,选择适当的哈希算法取决于具体的安全需求。在密码存储等敏感场景,推荐使用较强的哈希算法,如 SHA-256。

计算文件的md5值

计算文件的md5值(用rb模式读取字节),可以选择性加盐(b"abcdefg")

obj = hashlib.md5(b"abcdefg")
with open("wf.txt", mode="rb") as f:
for line in f:
obj.update(line) print(obj.hexdigest()) # 运行得到的结果
981efc8315eee7b0e1ba4540565daae5

计算文件的md5值,是为了判断文件的一致性——两个相同的文件的md5的值是相等的。

判断文件的MD5值的一致性有几个重要的用途:

  1. 文件完整性检查: MD5值是文件的唯一标识符,即使文件大小相同,只要文件内容有一点改变,其MD5值就会截然不同。通过比较文件的MD5值,可以检测文件是否在传输过程中发生了错误、损坏或被篡改。这在文件传输、存储和备份等场景中非常有用,确保文件在处理过程中保持完整性。

  2. 验证文件下载: 在下载文件时,用户可以通过比较下载后文件的MD5值与提供的MD5值来验证文件的完整性。这有助于确保文件在下载过程中没有被篡改(替换病毒文件、留下恶意后门)或损坏。

  3. 软件分发和更新: 在软件分发和更新的过程中,开发者通常提供文件的MD5值供用户验证。用户可以通过计算文件的MD5值并与提供的值比较,确保下载的软件包是原始、未经篡改的版本。

  4. 数据去重: 在存储大量文件的系统中,可以使用文件的MD5值来进行数据去重。相同内容的文件具有相同的MD5值,这可以帮助系统节省存储空间。

  5. 数字取证: 在数字取证和安全领域,MD5值常用于检测文件的变化,以确定是否存在潜在的安全威胁。

在我们上传文件的时候(百度网盘、QQ邮箱、QQ在线传文件),系统首先计算你要上传的这个文件的md5.拿着这个值去网盘的数据库中,搜索有没有相同的md5。如果有,就是已经上传过的(用户侧直接提示秒上传完成)。这样会大大节省网络传输压力和存盘空间压力。

Python——第五章:hashlib模块的更多相关文章

  1. Python第五章__模块介绍,常用内置模块

    Python第五章__模块介绍,常用内置模块 欢迎加入Linux_Python学习群  群号:478616847 目录: 模块与导入介绍 包的介绍 time &datetime模块 rando ...

  2. 简学Python第五章__模块介绍,常用内置模块

    Python第五章__模块介绍,常用内置模块 欢迎加入Linux_Python学习群  群号:478616847 目录: 模块与导入介绍 包的介绍 time &datetime模块 rando ...

  3. Python 入门之 内置模块 -- hashlib模块

    Python 入门之 内置模块 -- hashlib模块 1.hashlib 摘要算法,加密算法 (1)主要用途: <1> 加密 : md5 sha1 sha256 sha512 md5, ...

  4. 小白的Python之路 day5 hashlib模块

    hashlib模块 一.概述 用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法 二.算法的演 ...

  5. python全栈开发-hashlib模块(数据加密)、suprocess模块、xml模块

    一.hashlib模块 1.什么叫hash:hash是一种算法(3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法 ...

  6. Python操作数据库及hashlib模块

    一.hashlib模块 hashlib模块,主要用于加密相关的操作,在python3的版本里,代替了md5和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA51 ...

  7. python第五周:模块、标准库

    模块相关知识: 定义:用来从逻辑上组织python代码(变量.函数.类.逻辑:实现一个功能)本质就是以.py结尾的python文件(文件名:test.py,对应的模块名:test) 附注:包:是用来从 ...

  8. Python标准库之hashlib模块与hmac模块

    hashlib模块用于加密相关的操作.在Python 3.x里代替了md5模块和sha模块,主要提供 SHA1.SHA224.SHA256.SHA384.SHA512 .MD5 算法.如果包含中文字符 ...

  9. md5模块(Python内置模块)和hashlib模块

    转自https://my.oschina.net/duhaizhang/blog/67214 MD5模块用于产生消息摘要,康用来判断文件是否相同. python的md5模块使用非常简单,包括以下几个函 ...

  10. Python第五章实验报告

    一.实验项目名称:<零基础学Python>第五章实战.实例以及两道作业题 二.实验目的和要求:了解和掌握操作字符串的方法和正则表达式的应用 三.实验环境:IDLE(Python 3.9 6 ...

随机推荐

  1. ps--提升字体排版的美感四个有效方法

    一,文字的摆放位置 (字体的选择不要超过三种,分散注意力)

  2. Solution -「九省联考 2018」劈配

    Description Link. 一年一度的综艺节目<中国新代码>又开始了.Zayid 从小就梦想成为一名程序员,他觉得这是一个展示自己的舞台,于是他毫不犹豫地报名了. 轻车熟路的 Za ...

  3. Redis持久化 (RDB和AOF) 梳理

    Redis有两种持久化方案: RDB持久化 AOF持久化 RDB持久化 RDB全称Redis Database Backup file(Redis数据备份文件),也被叫做Redis数据快照.简单来说就 ...

  4. iptables和firewalld

    iptables简介 iptables不是一个单一的软件工具,而是一套c/s样式的软件组,它是由工作在用户空间的iptables和工作在内核空间的vetilter模块组成,一般统称为Iptables. ...

  5. Springboot+Guava实现单机令牌桶限流

    令牌桶算法 系统会维护一个令牌(token)桶,以一个恒定的速度往桶里放入令牌(token),这时如果有请求进来想要被处理,则需要先从桶里获取一个令牌(token),当桶里没有令牌(token)可取时 ...

  6. Redis系列之——Redis-Cluster

    文章目录 一 Redis Cluser介绍背景 1.1问题 1.2 解决 二 数据分布(分布式数据库) 2.1 存在问题 2.2 分区方式 2.2.1 顺序分区 2.2.2 哈希分区 2.2.2 .1 ...

  7. 使用ensp搭建路由拓扑,并使用ospf协议实现网络互通实操

    转载请注明出处: 1.使用ENSP 搭建如下拓扑: 数据准备 为完成此配置例,需准备如下的数据: 设备 Router ID Process ID IP地址 DeviceA 1.1.1.1 1 区域0: ...

  8. gestureRecognition

    这段代码定义了一个名为 gestureRecognition 的函数,它用于识别手势并显示在摄像头或指定图像上.以下是对代码的详细注释:1. 初始化一个空字符串 ges,用于存储手势结果.如果 sel ...

  9. Typora +Picgo 搭建个人笔记

    目录 Typora +Picgo 搭建个人笔记 一.Picgo +Github 搭建图床 1.基础设置 2. 将配置导出,方便下次使用 二.Typora:设置 : 1. 基本设置 2. 导出自动提交 ...

  10. 数据结构与算法 | 二叉树(Binary Tree)

    二叉树(Binary Tree) 二叉树(Binary Tree)是一种树形数据结构,由节点构成,每个节点最多有两个子节点:一个左子节点和一个右子节点. public class TreeNode { ...