当前位置: 首页 > news >正文

bcryptjs是什么、加密和对比过程是怎样的(初级版)

bcryptjs是什么?

bcryptjs是bcrypt的JavaScript实现,主要用于密码或其他字符串的加密(在Node.js中,bcrypt只能用来处理字符串,技术上可以用来处理其他诸如文件、对象等,但是花销的性能较大或者容易在加密过程中产生歧义),用于应对密码泄露或者数据库泄露以及密码的反向破解。

bcryptjs是如何进行加密的?

1.接收明文密码

2.生成随机的Salt(bcrypt自动完成)

同一个密码每次生成的Salt不同,这也是加密过程中“加盐”一次的来由。

3.设置cost(工作因子)

用于限定bcrypt的计算次数(2^cost次),cost每增加1,bcrypt的计算量都会翻倍,一般情况下我们会将cost定为10.

4.开始计算

不断用password+Salt扩展密钥,重复2^cost次,形成最终的storedHash(字符串)例如:

$2b$10$Ec3HpayMfx9EA.R4aH/.meKZQgEc8cYruU9JV8w2wWj5z/Lv4NyuW

拆解来看:

$2b$为bcrypt的版本

10 为cost

最后一段为Salt和hash,至于截至那里是Salt,只有bcrypt知道

bcrypt的核对过程是怎样的?

1.获取资源

拿到新的明文密码password和数据库存下的storedHash

2.资源解析

解析hash获取到bcrypt版本、cost、Salt以及hash

3.重新加密

利用新的明文密码password、解析得到的bcrypt版本、cost、Salt重新构造加密参数,然后执行bcrypt算法得到一个新的newStoredHash,将newStoredHash和storedHash做一次恒定时间比较,得出比对结果。这里所谓恒定时间比较参考 恒定时间比较示例代码分析 了解。

注:

bcrypt的加密是不可反推的,攻击者拿到storedHash只能解析到Salt+cost+hash,但是bcrypt加密是单向函数且有很高的计算成本(2^cost次),强行反推需要耗费很高的成本。

http://www.rkmt.cn/news/94259.html

相关文章:

  • SQL Server日期转换:传统方法与AI辅助效率对比
  • AI助力SQL Server 2016安装:自动生成安装脚本与配置指南
  • 【开题答辩全过程】以 雇主险信息管理系统为例,包含答辩的问题和答案
  • Python打印输出换行
  • 车辆MPC轨迹跟踪控制:双移线轨迹的追逐之旅
  • 3分钟原型开发:构建数组维度验证工具
  • AI如何帮你一键生成完美的JS深拷贝代码?
  • model.add
  • U盘无法访问:文件目录损坏且无法读取(上篇)
  • 企业级TLS升级实战:从TLSv1到TLSv1.2迁移指南
  • 探索MPC在电力电子与控制领域的奇妙之旅
  • 5分钟学会处理invalid_user_scode错误
  • 无刷直流电机模糊控制:Sfunction 函数与隶属度函数的奇妙之旅
  • 【开题答辩全过程】以 高校教材征订系统设计与开发为例,包含答辩的问题和答案
  • 我一个老运维,为啥把原版 Ubuntu 彻底卸了,换成这仨“亲儿子”
  • DataEase开源BI工具:如何选择最适合你的数据可视化版本
  • VSCode终极版 - 详解
  • WebSocket概念原理及使用注意事项 - 实践
  • 30 * 7 = 210
  • Ink/Stitch 开源刺绣设计软件:免费教程与完整使用指南
  • 全漏洞笔记--一些基本知识
  • 江苏抗台风抗风卷帘门厂家排名前十有哪些 - 品牌排行榜
  • 从微信红包延迟看超级应用高并发下的数据一致性攻坚
  • 我已经完全爱上沃玛了!
  • VLAN配置实验报告
  • GPT的前世今生
  • 逻辑回归简介
  • JavaScript 的垃圾回收对实时图形(60FPS)的影响:如何编写‘零 GC’代码实现物理引擎的稳帧运行
  • flask基础知识深入——会话管理:Flask Session从原生到扩展源码分析及使用
  • 边缘计算中的 JavaScript Isolates 架构:对比 Docker 容器在冷启动延迟、内存占用与多租户隔离上的优势