node.js - 使用 Passport 在 Node JS 中实现基于 cookie 的身份验证

标签 node.js cookies passport.js

下面是我的 server.js (app.js)。我正在使用带有 Passport 的 express ,用于用户身份验证。但是每当我重新启动我的 Node 服务器时,用户都会注销。

我是 nodejs 的新手,我想知道如何实现基于 cookie 的身份验证。这样即使服务器启动,用户也不会注销。我确定有一些我找不到的配置更改。

// server.js

// set up ======================================================================
// get all the tools we need
var express  = require('express');
var app      = express();
var port     = process.env.PORT || 80;
var mongoose = require('mongoose');
var passport = require('passport');
var flash    = require('connect-flash');

var morgan       = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser   = require('body-parser');
var session      = require('express-session');

var configDB = require('./config/database.js');

// configuration ===============================================================
mongoose.connect(configDB.url); // connect to our database

require('./config/passport')(passport); // pass passport for configuration

// set up our express application
app.use(morgan('dev')); // log every request to the console
app.use(cookieParser()); // read cookies (needed for auth)
app.use(bodyParser()); // get information from html forms

app.set('view engine', 'ejs'); // set up ejs for templating

// required for passport
app.use(session({ secret: 'yassers' })); // session secret
app.use(passport.initialize());
app.use(passport.session()); // persistent login sessions
app.use(flash()); // use connect-flash for flash messages stored in session

// routes ======================================================================
require('./app/routes.js')(app, passport); // load our routes and pass in our app and fully configured passport

// launch ======================================================================
app.listen(port);
console.log('The magic happens on port ' + port);

最佳答案

当您重新开始时它会注销,因为它存储在MemoryStore(RAM) 中。使用 mongoStore 来存储你的 session mongodb。试试下面的代码:

var session = require('express-session');
var MongoStore = require('connect-mongo')(session);

var mongoStore = new MongoStore({
  url: 'your mongo db url'  
});

app.use(session({
  secret: 'your secret',
  saveUninitialized: true, // don't create session until something stored
  resave: false, //don't save session if unmodified
  store: mongoStore,
  cookie: {
    domain: 'domain name',    
    maxAge: 1000 * 24 * 60
  }
}));

关于node.js - 使用 Passport 在 Node JS 中实现基于 cookie 的身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38158386/

相关文章:

javascript - 将一个 npm 模块编译成一个文件,没有依赖关系

session - Node.js expressjs session 不会停留在 Firefox 中

java - 如何从 WCF 客户端向 Java WebServices 发送多个 cookie

mysql - REST API、OAuth2 和身份验证错误

node.js - Passport 身份验证在sails.js 应用程序中不起作用

node.js - 使用 Node.js SDK 调用链代码时出错 [TypeError : Cannot read property 'getConnectivityState' of undefined]

javascript - MEAN/AngularJS 应用程序检查对象是否已发布

node.js - 在 Angular 5 中,如何导入没有 @types 的 NPM 模块

vba - 如何在VBA中设置和获取JSESSIONID cookie?

javascript - 需要了解 passport.js 本地策略