哈希函数简介

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

主要特点:

1、输出固定长度

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

2、快速计算

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

3、抗碰撞性

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

4、抗篡改性

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

5、不可逆性

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

常见哈希函数:
  • MD5:输出128位,曾广泛使用,但易遭受碰撞攻击。
  • SHA-1:输出160位,也曾被广泛使用,但已被发现存在安全漏洞,逐渐被淘汰。
  • SHA-256:SHA-2系列中的一种,输出256位,广泛用于安全应用,如数字签名和区块链技术。
  • SHA-3:新的安全哈希标准,设计上与SHA-2有所不同。
常见应用场景:
  • 数据完整性:用于文件下载、数据传输等场合,确保数据未被篡改。
  • 密码存储:将用户密码哈希后存储,增强安全性,防止明文泄露。
  • 数字签名:在签名过程前对消息进行哈希处理,以提高签名效率和安全性。
  • 区块链:区块链中每个区块通常包含前一个区块的哈希值,以确保区块链的不可篡改性。
相关推荐
wyiyiyi几秒前
【数据结构+算法】非递归遍历二叉树的理解
大数据·数据结构·笔记·算法·leetcode·数据分析
2401_893326628 分钟前
力扣1971.寻找图中是否存在路径
算法·leetcode·职场和发展
zs宝来了17 分钟前
HOT100-技巧类型题
数据结构·算法
Ayanami_Reii17 分钟前
进阶数据结构-FenwickTree
数据结构·算法·树状数组·fenwick tree
爪哇部落算法小助手23 分钟前
每日两题day59
数据结构·c++·算法
Brduino脑机接口技术答疑32 分钟前
脑机接口数据处理连载(二) 数据源头解析:脑电信号的采集原理与数据特性
人工智能·python·算法·数据分析·脑机接口
吃着火锅x唱着歌38 分钟前
LeetCode 1010.总持续时间可被60整除的歌曲
算法·leetcode·职场和发展
风筝在晴天搁浅38 分钟前
代码随想录 198.打家劫舍
算法
py有趣1 小时前
LeetCode算法学习之旋转矩阵
学习·算法·leetcode
三花聚顶<>1 小时前
310.力扣LeetCode_ 最小高度树_三种方法总结
算法·leetcode·职场和发展