网站首页 > 技术文章 正文
Bcrypt是一个跨平台的文件加密工具。
为了保护用户的明文密码不被泄露,一般会对密码进行单向不可逆加密——哈希。
而Bcrypt恰恰就做到这一点,通过Bcrypt加密的明文密码即使解密也不是真的“解密”,哪怕是内部人员,也不会看到密码。
这大大的提高了用户的安全级别。那么怎么使用呢?这里我用node的项目演示。
首先引入Bcrypt
yarn add bcrypt
这是一个用户注册时输入的密码
if (isSigned) {
res.render('user', {
ret: true,
data: JSON.stringify({
msg: '用户名已经存在!'
})
})
// 当用户没有注册时,首先将密码加密,再将用户名和加密后的密码入库
} else {
let result = await userModel.signup({
username,
password: await _doCrypto(password)
})
}
//将从前端接受到的password进行加密
const _doCrypto = (password) => {
return new Promise((resolve) => {
//这里的salt值,每次都是不一样的,也是根据取到不同的salt,所以每次的加密结果都不一样
bcrypt.genSalt(10, function (err, salt) {
bcrypt.hash(password, salt, function (err, hash) {
resolve(hash)
});
});
})
}
登录时我们可以这样进行验证
//密码认证
let isCorrect = await _comparePwd(password, result.password)
//通过_comparePwd方法将用户输入的明文与数据的加密过的进行比对
const _comparePwd = (fromUser, fromDatabase) => {
return new Promise((resolve) => {
bcrypt.compare(fromUser, fromDatabase, (err, res) => {
resolve(res)
})
})
}
为了系统的安全性与用户的体验,使用bcrypt加密工具还是必不可少的
猜你喜欢
- 2025-06-18 SQL注入:程序员亲手打开的潘多拉魔盒,如何彻底封印它?
- 2025-06-18 Java项目本地部署宝塔搭建实战Java物业小程序源码物业系统源码
- 2025-06-18 如何安全地保障用户Web登录安全?(web登录安全方案)
- 2025-06-18 如何发个 npm 包?(npm发包流程)
- 2025-06-18 大华信息安全|WEB和Configtool密码重置
- 2025-06-18 某实战项目登录口处的渗透测试(渗透实战测试平台)
- 2025-06-18 Spring Boot 中密码加密的两种姿势
- 2024-10-04 用户名或密码不正确?锁定? 用户名或密码不正确,请重新输入!
- 2024-10-04 通过sql注入获取用户名和密码 192.168.1.1路由器登录入口用户名和密码
- 2024-10-04 常见的密码攻击方式及防范措施 密码攻击是什么
你 发表评论:
欢迎- 533℃Oracle分析函数之Lag和Lead()使用
- 531℃几个Oracle空值处理函数 oracle处理null值的函数
- 529℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 520℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 515℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 505℃【数据统计分析】详解Oracle分组函数之CUBE
- 485℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 483℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端密码加密 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)