Bcrypt和PassportJs用户注册
创始人
2024-11-26 22:31:06
0

要实现使用Bcrypt和PassportJs进行用户注册,可以按照以下步骤进行:

  1. 安装所需的依赖:
npm install bcrypt passport passport-local express-session
  1. 创建一个名为app.js的主文件,并添加以下代码:
const express = require("express");
const session = require("express-session");
const passport = require("passport");
const LocalStrategy = require("passport-local").Strategy;
const bcrypt = require("bcrypt");

const app = express();
app.use(express.urlencoded({ extended: true }));
app.use(session({ secret: "secret", resave: false, saveUninitialized: false }));
app.use(passport.initialize());
app.use(passport.session());

// 模拟一个用户数据库
const users = [];

// 配置Passport本地策略
passport.use(
  new LocalStrategy((username, password, done) => {
    const user = users.find((user) => user.username === username);
    if (!user) {
      return done(null, false, { message: "Incorrect username." });
    }
    bcrypt.compare(password, user.password, (err, res) => {
      if (res) {
        return done(null, user);
      } else {
        return done(null, false, { message: "Incorrect password." });
      }
    });
  })
);

// 序列化和反序列化用户
passport.serializeUser((user, done) => {
  done(null, user.id);
});

passport.deserializeUser((id, done) => {
  const user = users.find((user) => user.id === id);
  done(null, user);
});

// 注册路由
app.get("/", (req, res) => {
  res.send("Home Page");
});

app.get("/register", (req, res) => {
  res.send(`
    

Register



`); }); app.post("/register", (req, res) => { const { username, password } = req.body; const hashedPassword = bcrypt.hashSync(password, 10); const newUser = { id: Date.now().toString(), username, password: hashedPassword }; users.push(newUser); res.redirect("/login"); }); app.get("/login", (req, res) => { res.send(`

Login



`); }); app.post( "/login", passport.authenticate("local", { successRedirect: "/profile", failureRedirect: "/login", }) ); app.get("/profile", isAuthenticated, (req, res) => { res.send(`

Welcome, ${req.user.username}!

`); }); app.get("/logout", (req, res) => { req.logout(); res.redirect("/"); }); // 中间件函数,用于检查用户是否已经登录 function isAuthenticated(req, res, next) { if (req.isAuthenticated()) { return next(); } res.redirect("/login"); } // 启动服务器 app.listen(3000, () => { console.log("Server started on port 3000"); });
  1. 运行应用程序:
node app.js

现在,你可以在浏览器中访问http://localhost:3000/register来注册新用户,然后使用注册的用户名和密码登录。登录后,你将被重定向到http://localhost:3000/profile,显示欢迎消息。你也可以在浏览器中访问http://localhost:3000/logout来注销用户。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...