node中使用bcrypt库加密、验证密码

install

npm install bcrypt --save

引入

const by = require('bcrypt');

常用方法

加密:

// 生成盐,参数为加密的强度(0~99),默认为10,值越高强度越大,但是解密验证的时候性能越低。
// salt是一个随机字符串
const salt = bcrypt.genSalt(10)
// 参数一:要加密的密码
// 参数二:生城的盐
// 异步方法:返回一个promise
bcrypt.hash(password, salt) 
// 同步方法:bcrypt.hashSync()

解密:

// 异步方法:返回一个promise
bcrypt.compare('原始密码', '加密之后的密码')
// 同步方法:
bcrypt.compareSync()

 完整例子:

(async function(){
    const bcrypt = require('bcrypt');
    const pas = '123'; // 原始密码
    const saltC = 10;
    let salt = await bcrypt.genSalt(saltC);
    let bcPassword = await bcrypt.hash(pas, salt);
    let compare = await bcrypt.compare(pas, bcPassword);
    // console.log('返回的是布尔值,比对成功返回true,否则false', compare)
})()

 

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js 使用 bcrypt 对字符串进行加密可以使用 `bcrypt` 模块。下面是一个简单的示例: ```javascript const bcrypt = require('bcrypt'); const saltRounds = 10; // 设置加盐的轮数,建议设置为 10 const plaintextPassword = 'myPassword123'; bcrypt.hash(plaintextPassword, saltRounds, function(err, hash) { if (err) { console.error(err); } else { console.log('Hashed password:', hash); } }); ``` 上面的代码,`bcrypt.hash()` 函数接收三个参数:待加密的明文密码、加盐的轮数、回调函数。回调函数,第一个参数是错误信息,第二个参数是加密后的哈希值。在上面的示例,我们使用 `console.log()` 输出了加密后的哈希值。 需要注意的是,在使用 bcrypt 进行密码验证时,需要使用 `bcrypt.compare()` 函数将输入的密码与数据的哈希值进行比对。示例代码如下: ```javascript const plaintextPassword = 'myPassword123'; const hash = '$2b$10$gkF5qzX7AuWpAUN8v7mC9eDp/09gmlTP4Wbq6VBhiEeBjT2BtDqOe'; bcrypt.compare(plaintextPassword, hash, function(err, result) { if (err) { console.error(err); } else { console.log('Password match:', result); } }); ``` 上面的代码,`bcrypt.compare()` 函数接收三个参数:输入的明文密码、数据保存的哈希值、回调函数。回调函数,第一个参数是错误信息,第二个参数是比对结果,如果输入的密码与数据的哈希值匹配,返回 `true`,否则返回 `false`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值