首页 web前端 js教程 在Express中使用bcryptjs密码加密

在Express中使用bcryptjs密码加密

Jun 07, 2018 pm 01:38 PM
express 密码加密

本篇文章主要介绍了Express下采用bcryptjs进行密码加密的方法,现在分享给大家,也给大家做个参考。

前几天利用Express开发了个小项目,开发登录注册模块时,采用bcryptjs进行密码加密,总结了一下内容:

bcrypt,是一个跨平台的文件加密工具。由它加密的文件可在所有支持的操作系统和处理器上进行转移。它的口令必须是8至56个字符,并将在内部被转化为448位的密钥。

除了对您的数据进行加密,默认情况下,bcrypt 在删除数据之前将使用随机数据三次覆盖原始输入文件,以阻挠可能会获得您的计算机数据的人恢复数据的尝试。如果您不想使用此功能,可设定禁用此功能。

bcrypt 使用的是布鲁斯·施内尔在1993年发布的 Blowfish 加密算法。具体来说,bcrypt 使用保罗·柯切尔的算法实现。随 bcrypt 一起发布的源代码对原始版本作了略微改动。

Express下bcryptjs的使用步骤:

1.安装bcryptjs模块

npm install bcryptjs --save
登录后复制

2.在需要加密的模块中引入bcryptjs库

var bcrypt = require('bcryptjs');
登录后复制

3.设置加密强度

var salt = bcrypt.genSaltSync(10);
登录后复制

4.注册时生成HASH值,并插入数据库

router.post('/register', function(req, res, next){
  // 从连接池获取连接
  pool.getConnection(function(err, connection) {
    // 获取前台页面传过来的参数
    var param = req.query || req.params;
    /*生成HASH值*/
    var hash = bcrypt.hashSync(param.pwd,salt);
    // 建立连接 新增用户
    connection.query(userSQL.insert, ["",hash,param.phone,"","","",0], function(err, result) {
      res.send(result);
      // 释放连接
      connection.release();
    });
  });
});
登录后复制

5.登录时验证HASH值,并插入数据库

router.post('/login', function(req, res, next){
  // 从连接池获取连接
  pool.getConnection(function(err, connection) {
    // 获取前台页面传过来的参数
    var param = req.query || req.params;
    // 建立连接 根据手机号查找密码
    connection.query(userSQL.getPwdByPhoneNumber, [param.phone], function(err, result) {
      if(bcrypt.compareSync(param.pwd,result[0].password)){
        res.send("1");
        connection.query(userSQL.updateLoginStatusById, [1,result[0].id], function(err, result) {
        });
      }else{
        res.send("0");
      }
      // 释放连接
      connection.release();
    });
  });
});
登录后复制

以上采用的是bcryptjs的同步用法,下面介绍异步用法:

生成hash密码:

bcrypt.genSalt(10, function(err, salt) {
  bcrypt.hash("B4c0/\/", salt, function(err, hash) {
    // Store hash in your password DB.
  });
});
登录后复制

密码验证:

bcrypt.compare("B4c0/\/", hash).then((res) => {
  // res === true
});
登录后复制

下面是使用Bcrypt对数据加密的一个简单的栗子:

var mongoose = require('mongoose');
// 引入bcrypt模块
var bcrypt = require('bcrypt');
// 定义加密密码计算强度
var SALT_WORK_FACTOR = 10;

// 连接数据库
mongoose.connect('mongodb://localhost:27017/test')

// 定义用户模式
var UserSchema = new mongoose.Schema({
  name: {
    unique: true,
    type: String
  },
  password: {
    unique: true,
    type: String
  }
},{ collection: "user"});

// 使用pre中间件在用户信息存储前进行密码加密
UserSchema.pre('save', function(next){
  var user = this;

  // 进行加密(加盐)
  bcrypt.genSalt(SALT_WORK_FACTOR, function(err, salt){
    if(err){
      return next(err);
    }
    bcrypt.hash(user.password, salt, function(err, hash){
      if(err){
        return next(err);
      }
      user.password = hash;
      next();
    })
  });
});

// 编译模型
var UserBox = mongoose.model('UserBox', UserSchema);

// 创建文档对象实例
var user = new UserBox ({
  name : "Jack" ,
  password : "123456"
});

// 保存用户信息
user.save(function(err, user){
  if(err){
    console.log(err);
  }else{
    // 如果保存成功,打印用户密码
    console.log("password: " + user.password);
  }
})
登录后复制

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在nodejs中通过redis作为缓存实现的封装缓存类

使用原生JavaScript实现放大镜效果

Vue Socket.io源码详细分析

以上是在Express中使用bcryptjs密码加密的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

node项目中如何使用express来处理文件的上传 node项目中如何使用express来处理文件的上传 Mar 28, 2023 pm 07:28 PM

怎么处理文件上传?下面本篇文章给大家介绍一下node项目中如何使用express来处理文件的上传,希望对大家有所帮助!

PHP密码加密及安全存储方法? PHP密码加密及安全存储方法? Jun 30, 2023 am 08:34 AM

如何在PHP处理密码加密和安全存储?随着互联网的快速发展,用户隐私和数据安全的保护成为了一个重要的问题。对于网站和应用程序开发者来说,确保用户密码的安全是至关重要的。在PHP语言中,有很多方法可以处理密码的加密和安全存储。本文将介绍一些常用的技术和最佳实践,帮助开发者加强用户密码的安全性。使用哈希函数进行密码加密在存储密码时,绝对不能以明文的形式存储,而是应

深入比较Express和Laravel:如何选择最佳框架? 深入比较Express和Laravel:如何选择最佳框架? Mar 09, 2024 pm 01:33 PM

深入比较Express和Laravel:如何选择最佳框架?在选择一个适合自己项目的后端框架时,Express和Laravel无疑是两个备受开发者欢迎的选择。Express是基于Node.js的轻量级框架,而Laravel则是基于PHP的流行框架。本文将深入比较这两个框架的优缺点,并提供具体的代码示例,以帮助开发者选择最适合自己需求的框架。性能和扩展性Expr

Express和Laravel的对比分析:选择更适合你的框架 Express和Laravel的对比分析:选择更适合你的框架 Mar 10, 2024 pm 10:15 PM

Express和Laravel是两个非常流行的Web框架,分别代表了JavaScript和PHP两大开发语言的优秀框架。本文将针对这两个框架进行对比分析,帮助开发者选择更适合自己项目需求的框架。一、框架简介Express是一个基于Node.js平台的Web应用程序框架,它提供了一系列强大的功能和工具,使开发者可以快速搭建高性能的Web应用程序。Express

如何使用PHP实现密码加密功能 如何使用PHP实现密码加密功能 Aug 19, 2023 am 09:16 AM

如何使用PHP实现密码加密功能密码是我们在生活和工作中常常需要使用的一种安全验证方式。为了保护用户的隐私,我们必须将用户的密码进行加密存储,以免被不法分子盗取和滥用。本文将介绍如何使用PHP实现密码加密功能,以增加用户密码的安全性。在PHP中,有一个非常强大的加密函数password_hash()可以用于生成密码的哈希值。该函数可以接受两个参数:明文密码和一

深入剖析MySQL密码加密方法 深入剖析MySQL密码加密方法 Jun 15, 2023 pm 09:24 PM

随着互联网的发展,MySQL作为一种开源的关系型数据库管理系统,在各类应用中都有广泛应用。其中一个重要的安全问题就是MySQL用户密码的加密和存储。那么,MySQL密码加密的方法都有哪些呢?本文将为大家深入剖析。MySQL密码的存储方式在了解MySQL密码加密方法之前,先来了解一下MySQL密码的存储方式。MySQL在版本5.7以前,采用的是单向哈希算法(S

PHP和SQLite:如何实现密码加密和验证 PHP和SQLite:如何实现密码加密和验证 Jul 29, 2023 am 10:17 AM

PHP和SQLite:如何实现密码加密和验证引言:在现代互联网时代,用户密码的安全性显得尤为重要。为了保护用户的隐私,网站普遍采用密码加密和验证的方法来存储和处理用户的密码信息。本文将介绍如何使用PHP和SQLite数据库来实现密码加密和验证功能。一、密码加密密码的加密是指将用户的明文密码转化为一段看似不可读的随机字符串,通过这种转化过程,即使数据库泄露,也

如何使用PHP和Vue.js开发可靠的密码加密与解密系统 如何使用PHP和Vue.js开发可靠的密码加密与解密系统 Jul 05, 2023 pm 08:53 PM

如何使用PHP和Vue.js开发可靠的密码加密与解密系统引言:在网络世界中,密码的安全性尤为重要。为了保护用户的隐私和安全,我们需要使用可靠的密码加密与解密系统。在本文中,我们将介绍如何使用PHP和Vue.js开发一个可靠的密码加密与解密系统,并附上代码示例。一、了解密码加密与解密的原理在开始开发之前,我们需要了解密码加密与解密的原理。一般而言,我们使用哈希

See all articles