【发布时间】:2012-08-03 08:04:07
【问题描述】:
我有一个快递应用程序,我有一个登录表单。我需要会话持续 1 个月,我是否将 maxAge 设置为以毫秒为单位的一个月。
我将两台计算机都打开并登录了 24 小时,当我回来时,两台计算机都已注销。
我该如何解决这个问题/实现我想要做的事情? 谢谢。
【问题讨论】:
标签: javascript node.js session express
我有一个快递应用程序,我有一个登录表单。我需要会话持续 1 个月,我是否将 maxAge 设置为以毫秒为单位的一个月。
我将两台计算机都打开并登录了 24 小时,当我回来时,两台计算机都已注销。
我该如何解决这个问题/实现我想要做的事情? 谢谢。
【问题讨论】:
标签: javascript node.js session express
@Vadim Baryshev 接受的答案至少在最近的快速会话实现中存在缺陷。当您的应用程序启动时,您创建会话实现并设置最大年龄。至于用expires的答案,不推荐,坚持maxAge。
这意味着所写的 maxAge 示例将在服务器启动一个月后的每个会话中过期,并且将来创建的每个会话都将立即过期。在服务器重新启动之前,不会有任何有效的会话。
无需传递日期对象,只需将毫秒数传递给 maxAge 属性,如下所示:
app.use(
session({
...,
cookie: {
maxAge: 30 * 24 * 60 * 60 * 1000
}
})
);
【讨论】:
您可以使用 expires 属性而不是 maxAge。它将 Date 对象作为值。此外,设置后检查客户端上的会话 cookie 过期。可能会话由服务器结束(即 memcached 重启)。
代码示例:
app.use(express.session(
{ secret: "secret", store: new MemoryStore(), expires: new Date(Date.now() + (30 * 86400 * 1000))
}));
但是
app.use(express.session(
{ secret: "secret", store: new MemoryStore(), maxAge: Date.now() + (30 * 86400 * 1000)
}));
对我也很好。
【讨论】:
MemoryStore 仅在 express 应用程序运行期间存储会话。因此,如果您在任何时候重新启动服务器,cookie 将不再链接到内存中的会话,并且 express 将使您的用户再次登录。
Date.now() 不正确
maxAge 表示会话持续多长时间,以毫秒为单位;
expires 表示会话何时到期,即:日期对象
var hour = 3600000
req.session.cookie.expires = new Date(Date.now() + hour)
或
var hour = 3600000
req.session.cookie.maxAge = hour
【讨论】:
文档不建议直接设置 cookie.expires。相反,直接设置 cookie.maxAge。
【讨论】:
app.use(express.session({
secret : 'sdfsdSDFD5sf4rt4egrt4drgsdFSD4e5',
store : new storage({ client : conn, cleanup: false }),
cookie : { maxAge : new Date(Date.now() + (60 * 1000 * 30)) }
}));
【讨论】: