// 引入Express和相关中间件
const express = require('express');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');
const session = require('express-session');
const passport = require('passport');
// 创建Express应用
const app = express();
// 连接MongoDB数据库
mongoose.connect('mongodb://localhost:27017/node-login-example', { useNewUrlParser: true });
// 使用body-parser中间件解析请求体
app.use(bodyParser.urlencoded({ extended: true }));
// 使用express-session中间件进行会话管理
app.use(session({
secret: 'secret',
saveUninitialized: true,
resave: true
}));
// 使用Passport中间件进行身份验证
app.use(passport.initialize());
app.use(passport.session());
// 定义Passport的本地策略
passport.use('local', new LocalStrategy({
usernameField: 'email',
passwordField: 'password',
passReqToCallback: true
},
function(req, email, password, done) {
// 实现用户验证逻辑
}
));
// 定义Passport的序列化和反序列化方法
passport.serializeUser(function(user, done) {
done(null, user.id);
});
passport.deserializeUser(function(id, done) {
// 实现用户信息查询逻辑
});
// 定义路由
app.get('/', function(req, res) {
res.send('Hello World!');
});
// 用户登录路由
app.post('/login', passport.authenticate('local', { failureRedirect: '/login' }), function(req, res) {
res.redirect('/');
});
// 用户注册路由
app.post('/register', function(req, res) {
// 实现用户注册逻辑
});
// 启动服务器
app.listen(3000, function() {
console.log('Server started on port 3000');
});
这个简化版的代码示例展示了如何使用Express框架搭建一个具有登录和注册功能的Node.js应用,同时使用了Passport进行身份验证,Mongoose进行数据库操作,以及express-session进行会话管理。虽然示例中的登录和注册逻辑需要进一步实现,但是这个框架可以作为开始构建实际应用的基础。