Node.js - Express session 数据不持久

标签 node.js express session express-session

登录按预期工作并返回 session 数据,但除此之外我无法让 session 数据持续存在。例如,当我调用 getUser(如下)时,不会返回 session 数据。

app.js(设置)

const express = require('express')
const bodyParser = require('body-parser')
const cors = require('cors')
const morgan = require('morgan')
const request = require('request')
var session = require('express-session');
var MongoStore = require('connect-mongo')(session);

const app = express()
app.use(morgan('combined'))
app.use(bodyParser.json())
app.use(cors({
    credentials: true
}))

const mongodb_conn_module = require('./mongodbConnModule');
var db = mongodb_conn_module.connect();

app.use(session({
    secret: 'work hard',
    resave: false,
    saveUninitialized: true,
    cookie: {
        secure: false,
        maxAge: 24 * 60 * 60 * 1000
    },
    store: new MongoStore({
        mongooseConnection: db,
        ttl: 24 * 60 * 60 // Keeps session open for 1 day
    })
}));

app.js(登录)

app.post('/login', (req, res) => {
    if (req.body.logEmail && req.body.logPassword) {
        Users.authenticate(req.body.logEmail, req.body.logPassword, function (error, user) {
            if (error || !user) {
                var err = new Error('Wrong email or password.');
                err.status = 401;
                res.send("Wrong email or password.");
            } else {
                req.session.userId = user._id;
                res.send({
                    success: true,
                    sessionInfo: req.session
                });
            }
        });
    } else {
        var err = new Error('All fields required.');
        err.status = 400;
        res.send("All fields required.");
    }
})

返回 session 数据(userId) enter image description here

app.js(getUser)

app.get('/get_user', (req, res) => {
    res.send(req.session)
})

这似乎会删除 session 数据 enter image description here

UsersService.js(模型)

var mongoose = require("mongoose");
var bcrypt = require('bcrypt');
var Schema = mongoose.Schema;

var UserSchema = new Schema({
    firstName: {
        type: String,
        required: true
    },
    lastName: {
        type: String,
        required: true
    },
    userName: {
        type: String,
        unique: true,
        required: true,
        trim: true
    },
    email: {
        type: String,
        unique: true,
        required: true,
        trim: true
    },
    password: {
        type: String,
        required: true,
    },
    passwordConf: {
        type: String,
        required: true,
    }
});

//authenticate input against database
UserSchema.statics.authenticate = function (email, password, callback) {
    Users.findOne({ email: email })
        .exec(function (err, user) {
            if (err) {
                return callback(err)
            } else if (!user) {
                var err = new Error('User not found.');
                err.status = 401;
                return callback(err);
            }
        bcrypt.compare(password, user.password, function (err, result) {
            if (result === true) {
                return callback(null, user);
            } else {
                return callback();
            }
        })
    });
}

// hashing a password before saving it to the database
UserSchema.pre('save', function (next) {
    var user = this;
    bcrypt.hash(user.password, 10, function (err, hash) {
        if (err) {
            return next(err);
        }
        user.password = hash;
        next();
    })
});

var Users = mongoose.model("Users", UserSchema);
module.exports = Users;

提前致谢!

最佳答案

经过大量工作后,我刚刚解决了同样的问题,因为 app.js (设置)中的顺序不好,因此通过此代码编辑 app.js (设置)希望对你有帮助:)

const express = require('express')
const bodyParser = require('body-parser')
const cors = require('cors')
const morgan = require('morgan')
const request = require('request')
var session = require('express-session');
var MongoStore = require('connect-mongo')(session);

const app = express()
    app.use(session({
            secret: 'work hard',
            resave: false,
            saveUninitialized: true,
            cookie: {
                secure: false,
                maxAge: 24 * 60 * 60 * 1000
            },
            store: new MongoStore({
                mongooseConnection: db,
                ttl: 24 * 60 * 60 // Keeps session open for 1 day
            })
    app.use(bodyParser.json())
    app.use(bodyParser.urlencoded({ extended: false }));

    app.use(morgan('combined'))
    app.use(cors({
        credentials: true
    }))
});
app.use(cors({
    credentials: true
}))

const mongodb_conn_module = require('./mongodbConnModule');
var db = mongodb_conn_module.connect();


}));

关于Node.js - Express session 数据不持久,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53350332/

相关文章:

javascript - 为什么我的 ejs 不在重定向时呈现?

javascript - 无法在expressjs中为前端和后端使用多个静态路径

asp.net-mvc - MVC 在 session 中保存 token

python - npm 安装 bcrypt,gyp 错误! Python

javascript - Express app.use 带有可选参数的路由

node.js - Azure Web 应用程序 : deploying Angular SPA & Node Express server from Github repository

mongodb - Swagger项目创建命令行错误

node.js - jQuery slider 在 angularjs 中不起作用

session - 如何在 Node.js 中管理 session

java - 如何访问 session .jsp 文件中的应用程序数据