我是靠谱客的博主 醉熏音响,最近开发中收集的这篇文章主要介绍bcryptjs密码加密,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

bcryptjs密码加密

文章目录

      • bcryptjs密码加密
        • 一.背景
        • 二.md5加密
          • 1.安装 js-md5
          • 2.使用
          • 3.md5加密的缺点
        • 三.bcryptjs加密
          • 1.bcryptjs是nodejs中比较好的一款加盐(salt)加密的包.
          • 2.安装
          • 3.使用

一.背景

​ 我们开发过程中,经常会写登录注册之类功能,还有一些数据安全性比较高的功能,都会用到加密,然后存在数据库中,如果数据库暴露了,密码是未加密的,后果可想而知.

二.md5加密

​ md5是一种被广泛使用的密码散列函数,可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输完整一致。通常将128位MD5哈希表示为32位十六进制值

​ 下面我这边使用nodejs的语法,来做后台处理程序

1.安装 js-md5
 $
npm install js-md5
2.使用
const md5=require('js-md5');
console.log(md5("123456"));//e10adc3949ba59abbe56e057f20f883e
3.md5加密的缺点

1理论上是不能破解的,因为md5采用的是不可逆算法。

2.有的网站上提供MD5解密,是因为有大量的存储空间来保存源码和加密后的密码,当解密时就是一个查询的过程,稍微复杂点的查询就无法完成。这种解密方式,叫做 字典攻击

三.bcryptjs加密

​ 密码不能以明文形式保存到数据库中,否则数据泄露密码就会被知道`。而一般的加密方式由于加密规则固定,很容易被破解,安全系数不高。密码加盐的加密方式,能很好的解决这一点。解决字典攻击的方式 是加盐.

1.bcryptjs是nodejs中比较好的一款加盐(salt)加密的包.

所谓加盐.就是系统生成一串随机值,然后混入原始密码中,然后按照加密方式生成一串字符串保存在服务器。

2.安装

npm地址

$ npm install bcryptjs
3.使用
/**
* bcryptjs
加密
*/
const bcryptjs = require('bcryptjs');
const password = '123456';
/**
* 加密处理 - 同步方法
* bcryptjs.hashSync(data, salt)
*
- data
要加密的数据
*
- slat
用于哈希密码的盐。如果指定为数字,则将使用指定的轮数生成盐并将其使用。推荐 10
*/
let hasPwd=bcryptjs.hashSync(password, 10);
/**
* 注意:每次调用输出都会不一样
*/
console.log(hasPwd) // $2a$10$y5WA7lOVpzxVh.pqK3kUzOFZaJZXUMutvb3EG0qocgRxGcKQG36ou
/**
* 校验 - 使用同步方法
* bcryptjs.compareSync(data, encrypted)
*
- data
要比较的数据, 使用登录时传递过来的密码
*
- encrypted
要比较的数据, 使用从数据库中查询出来的加密过的密码
*/
let comparePwd=bcryptjs.compareSync(password,'$2a$10$OIYc/KLDcBdHf8Ww9uKbG.CLxdGBMLSQ0h7l4c0G7ED7.fqmpb4B6');
console.log(comparePwd);//true

参考链接

最后

以上就是醉熏音响为你收集整理的bcryptjs密码加密的全部内容,希望文章能够帮你解决bcryptjs密码加密所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部