使用 Express Cookie-Session 生成唯一的 sessionId

问题描述

我在我的应用程序中使用 node/express.jscookie-session

目前,当用户登录时,cookie 会在浏览器中存储一个值,例如:session: ABC123。如果用户退出,cookie 将被删除。当用户重新登录时,相同的 cookie 和值会存储在浏览器 session: ABC123 中。

enter image description here

每当我登录时,我都会收到相同的会话 user_sid

我想在用户每次登录随机化会话 user_sid

解决方法

您想在用户成功登录时调用 session.regenerate(),这将执行您想要的操作并解决会话固定攻击

,

cookie-session 包中没有会话 ID 的概念。

在会话数据存储在服务器上的典型场景中,会生成映射到给定用户会话数据的会话 ID。这是会话 cookie 中保存的会话 ID。

然而,使用 cookie-session 包,会话数据本身存储在 cookie 中 - 而不是在服务器上 - 所以根本不需要这样的映射或会话 ID。因此,除非会话数据实际上从一个会话更新到另一个会话,否则会话 cookie 将是相同的。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...