当前位置: 首页 > 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.jsqmd.com/news/84052/

相关文章:

  • 2025爆火7款免费AI写论文神器:一键生成初稿,限时公开! - 麟书学长
  • 传统VS AI:M3U8解析效率提升10倍的秘密
  • 探索基于LS-DYNA的弹体斜侵彻冲击起爆炸药模拟:从SALE方法到举一反三
  • 实战:用快马平台3步搭建M3U8视频下载器
  • AI如何帮你掌握Linux mv命令的高级用法
  • SQL Server日期转换:传统方法与AI辅助效率对比
  • AI如何帮你轻松掌握document.querySelector
  • CPU缓存分级的示意图
  • AI助力SQL Server 2016安装:自动生成安装脚本与配置指南
  • LLC 谐振变换器的 Simulink 仿真探索
  • 1分钟原型:用parseInt构建URL分页参数解析器
  • 【开题答辩全过程】以 雇主险信息管理系统为例,包含答辩的问题和答案
  • Day29渐变及综合案例
  • 京东热销商品AI推荐系统开发指南
  • 【开题答辩全过程】以 公寓出租系统为例,包含答辩的问题和答案
  • 从0基础到完全掌握AD 第10讲 工程的创建和删除
  • Python打印输出换行
  • 车辆MPC轨迹跟踪控制:双移线轨迹的追逐之旅
  • Blazor WASM 程序打包器【都昌电子病历编辑器最新特性】
  • CISP-PTE备考神器:3周高效通关秘籍
  • 3分钟原型开发:构建数组维度验证工具
  • HarmonyOS —— NetworkKit 网络连接管理实战笔记
  • AI如何帮你一键生成完美的JS深拷贝代码?
  • GMSL小白入门:3步用AI搭建你的第一个视频传输项目
  • model.add
  • 时代周刊致敬“AI建筑师”,Anthropic 豪掷210亿买算力,蚂蚁开源 LLaDA 2.0,谷歌 NotebookLM 升级
  • U盘无法访问:文件目录损坏且无法读取(上篇)
  • 深入解析 ZooKeeper 3.5.7 配置文件 zoo.cfg —— 每个参数的用途与场景详解 - 详解
  • 零基础入门:5分钟学会制作酷炫WUB音效
  • 如何在没有软件的情况下从U盘恢复已删除的文件(下篇)