news 2026/5/22 20:14:11

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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次),强行反推需要耗费很高的成本。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 11:22:13

9、Puppet 中的变量、表达式、事实以及 Hiera 数据管理

Puppet 中的变量、表达式、事实以及 Hiera 数据管理 1. Puppet 中的迭代:each 函数的使用 在 Puppet 中,当我们需要创建多个相似的资源时,手动编写每个资源会非常繁琐。例如,创建三个不同编号的脚本资源,除了任务编号不同外,其他属性都相同。如果后续需要修改脚本属性,…

作者头像 李华
网站建设 2026/5/19 8:48:55

电商系统中MyBatis‘小于等于‘查询实战案例

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个电商商品查询模块,实现按价格区间筛选商品功能。要求使用MyBatis动态SQL,能够查询价格小于等于指定值的商品。包含以下功能:1) 基础查询…

作者头像 李华
网站建设 2026/5/22 17:38:25

二叉树延伸:堆结构与 TopK 问题的深度绑定与优化

目录 前言 树 非树 树的相关术语 二叉树 二叉树的分类 计算完全二叉树和满二叉树的高度和结点数 二叉树的存储结构 顺序结构 链式结构 实现顺序结构二叉树 堆的概念与结构 堆的实现 堆的初始化 堆的值交换 获取堆顶元素、堆的数据个数、堆的判空、堆的销毁 *建…

作者头像 李华
网站建设 2026/5/23 14:24:14

企业IT实战:安全获取微软系统镜像的3种方法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个企业级微软系统下载管理器,支持批量获取Windows各版本直链,自动验证数字签名,生成下载报告。包含断点续传功能和企业内网分发方案。点击…

作者头像 李华
网站建设 2026/5/23 15:19:49

比手动快10倍!用mv命令组合提升文件操作效率

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个效率对比工具,左侧展示传统GUI文件操作步骤,右侧展示等效的mv命令组合。包含以下对比场景:1) 分散文件收集整理 2) 按扩展名分类 3) 批量…

作者头像 李华
网站建设 2026/5/18 23:08:23

21、Puppet 环境配置与节点管理全解析

Puppet 环境配置与节点管理全解析 1. 用户数据处理与 SSH 配置 在进行系统配置时,我们首先会将所有用户数据通过 lookup() 函数提取到一个名为 $users 的哈希中。之后遍历这个哈希,为每个用户声明一个 accounts::user 资源,其属性从哈希数据中加载。需要注意的是,在…

作者头像 李华