哈希函数简介

哈希函数是一种将任意大小的数据输入(通常称为"消息")转换为固定大小的输出(称为"哈希值"或"摘要")的算法。

主要特点:

1、输出固定长度

无论输入数据的大小如何,哈希函数的输出总是固定长度。例如,SHA-256的输出始终为256位(32字节)。

2、快速计算

哈希函数应该能够快速计算,对于任何输入都能在合理的时间内生成哈希值。

3、抗碰撞性

理想的哈希函数应该难以找到两个产生相同的哈希值的不同输入,这种特性称为抗碰撞性。

4、抗篡改性

对输入数据进行任何小的修改,输出的哈希值应该发生显著变化。这使得哈希函数适合用于数据完整性检查。

5、不可逆性

哈希函数是单向的,无法从哈希值反推原始输入。这意味着一旦数据被哈希,就不能从哈希值恢复出原始数据。

常见哈希函数:
  • MD5:输出128位,曾广泛使用,但易遭受碰撞攻击。
  • SHA-1:输出160位,也曾被广泛使用,但已被发现存在安全漏洞,逐渐被淘汰。
  • SHA-256:SHA-2系列中的一种,输出256位,广泛用于安全应用,如数字签名和区块链技术。
  • SHA-3:新的安全哈希标准,设计上与SHA-2有所不同。
常见应用场景:
  • 数据完整性:用于文件下载、数据传输等场合,确保数据未被篡改。
  • 密码存储:将用户密码哈希后存储,增强安全性,防止明文泄露。
  • 数字签名:在签名过程前对消息进行哈希处理,以提高签名效率和安全性。
  • 区块链:区块链中每个区块通常包含前一个区块的哈希值,以确保区块链的不可篡改性。
相关推荐
kkeeper~3 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs6665 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964135 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚5 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本6 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov7 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫7 小时前
特征工程处理
人工智能·算法·机器学习
z落落8 小时前
C#参数区别
java·算法·c#
c238568 小时前
vector(下)
数据结构·算法
z落落9 小时前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法