首页 > 解决方案 > 使用 req.session.userID 时出错

问题描述

我正在使用 req.session.userID 变量为用户设置 sessionID。我的代码是

在服务器端,

router.post('/signin', bodyParser.json(),function(req, res){
var db = req.db;
var collection = db.get('userCollection');
var name = req.body.name;
var password = req.body.password;
name = name.trim();
password = password.trim();

collection.find({"name":name}, {}, function(e1, username){
    if (e1 === null){

        if (username[0].password == password) {
            req.session.userID = username[0]._id;
            var string2 = "before session" + req.session.userID + "after session" + username[0]._id;
            res.send(string2);
        }
        else {
            res.send("Failure!");
        }
    }
});

在客户端

router.post('/signin', bodyParser.json(),function(req, res){
var db = req.db;
var collection = db.get('userCollection');
var name = req.body.name;
var password = req.body.password;
name = name.trim();
password = password.trim();

collection.find({"name":name}, {}, function(e1, username){
    if (e1 === null){

        if (username[0].password == password) {
            req.session.userID = username[0]._id;
            var string2 = "before session" + req.session.userID + "after session" + username[0]._id;
            res.send(string2);
        }
        else {
            res.send("Failure!");
        }
    }
});

正如其他一些答案中所建议的那样,我还在我的 app.js 中设置了一个秘密令牌,但是每当我使用 req.session.userID 时,它都会给我一个错误。

当我删除 req.session.userID 并返回一个正常的语句时,它就可以工作了。谁能告诉我这可能是什么原因。

我的 app.js 看起来像这样......

var session = require('express-session');
app.use(session({
    secret: 'secret token'
}))

我什至安装了快速会话。我也应该做点别的吗?完整的 app.js 代码,

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var session = require('express-session');


var mongo = require('mongodb');
var monk = require('monk');
var db = monk('localhost:27017/learnproject1');

var logger = require('morgan');

var bodyParser = require('body-parser');
var indexRouter = require('./routes/myroutes.js');
//var userRouter = require('.')

var app = express();



// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());

app.use(express.static(path.join(__dirname, 'public')));
app.use(bodyParser.json());

app.use(function(req,res,next){
    req.db = db;
    next();
});

app.use('/', indexRouter);
//app.use('/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

app.use(session({
    secret: 'secret token'
}))
// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

标签: node.jsexpress

解决方案


推荐阅读