我按照教程使用passport-google-oauth
模块为我的网络应用程序添加了Google身份验证。 server.js文件包含以下代码行:
app.use(express.session({ secret: 'victoriassecret' })); // session secret
app.use(passport.initialize());
app.use(passport.session()); // persistent login sessions
此外,我发现应用程序会在一段时间后自动将用户注销。 Passport配置在server.js中导入的单独文件中。有没有什么方法可以在用户退出之前增加时间,甚至更好,在他点击退出按钮之前不记录他?此外,会议秘密是什么?
答案 0 :(得分:1)
1)您可以使用cookie参数的maxAge选项定义会话cookie的最长生命周期(同时也是用户自动注销之前的时间),如下所示:
app.use(expressSession({ cookie: {maxAge: 10000} , secret: 'victoriassecret'}));
根据此maxAge值(10000),cookie的最长生命周期为10.000毫秒(10秒)。 (显然你需要比这更大的价值)
因此,您可以增加maxAge值以满足您的需求,并确保用户在他决定之前不会退出,按下Logout按钮。
2)会话密钥是一个随机字符串,用于散列与HMAC的会话(更多关于HMAC:here),以保护会话不被劫持。