当客户端发出HTTP请求,并且该请求不包含会话cookie时,将通过创建新会话
express-session。创建一个新的会话可以做一些事情:
- 生成唯一的会话ID
- 将该会话ID存储在会话cookie中(以便可以识别客户端的后续请求)
- 创建一个空的会话对象,如下
req.session
- 根据的值
saveUninitialized
,在请求结束时,会话对象将存储在会话存储区中(通常是某种数据库)
如果在请求的生存期内未修改会话对象,则在请求结束时且
saveUninitialized为 false时
,(由于未修改,仍为空)会话对象将不会存储在会话存储中。
其背后的原因是,这将防止在会话存储中存储大量空的会话对象。由于没有什么可存储的,因此在请求结束时会“忘记”该会话。
您何时要启用此功能?例如,当您希望能够确定重复访问者时。您将能够识别出这样的访客,因为他们发送包含唯一ID的会话cookie。
关于
resave:可能必须为不支持“
touch”命令的会话存储启用此功能。这样做是告诉会话存储特定会话仍处于活动状态,这是必需的,因为某些存储将在一段时间后删除空闲(未使用)的会话。
如果会话存储驱动程序未实现touch命令,则应启用
resave该功能,以便即使在请求期间未更改会话,该会话仍会在存储中更新(从而将其标记为活动状态)。
因此,是否需要启用此选项完全取决于您使用的会话存储。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)