网站首页 > 技术文章 正文
在 nodejs 中有专门用于加密算法处理的模块 crypto,在开发中经常会用到其中的 hash 算法来处理数据,下面介绍下 crypto 中的常用 hash 算法 md5 和 sha。
哈希算法(md5 sha)
类型
crypto 中的哈希算法主要有以下类型:
- md5:用于生成固定长度为 128 位的哈希值。曾经是一种广泛应用在数据完整性验证和密码哈希存储的 hash 函数,但几年前其已被证明存在严重的安全漏洞,特别是在碰撞攻击方面,它不再被推荐用于安全性要求高的应用场景。
- SHA 系列:SHA 系列算法和 md5 一样用于生成固定长度的哈希值,它们在信息安全领域中应用广泛,如数据完整性验证、数字签名、密码存储等。与 md5 不同的是 sha 系列一直在更新,他们最近的版本安全性一直较高,如 sha-2/sha-3 不同的改进版本支持生成不同长度的哈希值。
应用
应用场景
- 用来安全加密(token 生成,敏感信息加密等)
- 做唯一性校验(文件类的生成 hash 值做唯一性校验)
- 数据完整性校验
- 密码存储
特点
哈希算法对于前端来说应该是比较常用的算法之一,其功能是把任意长度的输入,通过散列算法变换成固定长度的输出。其具备以下特点:
- 长度固定:无论输入的数据长度多少输出的长度固定。
- 输出值固定:相同的数据输入,输出的值完全相同。
- 效率高:散列函数能够快速计算哈希值,适合在需要高效处理的应用中使用。
- 不可逆:从输出的 hash 值无法推算出输入的值。
- 抗碰撞:很难找到两个不同的输入数据具有相同的哈希值。虽然在理论上碰撞是可能的,但好的散列函数使得找到碰撞在计算上非常困难。
- 雪崩性:输入数据的微小变化会导致输出的 hash 值有巨大变化
使用
- createHash(algorithm): 该方法用于创建一个 hash 对象,该对象可以使用指定的算法生成数据的 hash 值。 流程如下:指定哈希算法=》创建hash对象=》传入需要生成hash值的数据=》设置返回值编码=》返回hash值 algorithm 是个枚举值目前有:'md5'、'sha1'、'sha256'、'sha512' ... 对象上有方法 update 和 digest,update 更新 Hash 对象的内容,传入要哈希的数据,digest设置返回值编码并返回哈希摘要。
猜你喜欢
- 2025-06-09 平面几何算法:求点到直线和圆的最近点
- 2025-06-09 解决雪花算法生成的ID传到前端后精度丢失问题
- 2025-06-09 什么是非对称加密算法?(什么是非对称加密,有哪些特点)
- 2025-06-09 React18的diff算法(react-diff-view)
- 2025-06-09 「算法题」判断一颗二叉树是否对称
- 2025-06-09 经典监督式学习算法 - 决策树(决策监督制度)
- 2025-06-09 「西瓜哥说算法」从前序与中序遍历序列构造二叉树
- 2024-09-29 前端算法面试题 前端面试题csdn
- 2024-09-29 每天一道算法题——最长连续递增序列
- 2024-09-29 高级前端开发带你搞懂vue的diff算法
你 发表评论:
欢迎- 07-07使用AI开发招聘网站(100天AI编程实验)
- 07-07Tailwindcss 入门(tailwindcss中文文档)
- 07-07CSS 单位指南(css计量单位)
- 07-07CSS 定位详解(css定位属性的运用)
- 07-07程序员可以作为终身职业吗?什么情况下程序员会开始考虑转行?
- 07-07云和学员有话说:国企转行前端开发,斩获13K高薪!
- 07-0791年转行前端开发,是不是不该转,有啥风险?
- 07-07计算机图形学:变换矩阵(图形学 矩阵变换)
- 594℃几个Oracle空值处理函数 oracle处理null值的函数
- 587℃Oracle分析函数之Lag和Lead()使用
- 575℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 572℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 568℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 561℃【数据统计分析】详解Oracle分组函数之CUBE
- 548℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 541℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- 前端获取当前时间 (50)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)