javascript - Express session 变量不会跨请求持续存在

标签 javascript node.js express session-variables express-session

我正在尝试使用 express-session 模块让 session 变量在我的 Express Node.js 项目中工作。我没有收到任何错误,并且设置 session 变量似乎有效,但它们不会跨请求持续存在。这是我的代码的简化部分:

server.js

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

var app = express();

app.use(bodyParser.json());
// Sessions
app.use(session({
    secret: config.secret
}));

app.use('/api/projects', require('./controllers/api/projects'));

var server = app.listen(3000, function() {
    console.log('Server listening on', 3000)
});

api/projects.js 路由器

var router = require('express').Router()

router.get('/set', function(req, res, next) {
    req.session.test = "test";
    res.status(200).json({"test":req.session.test});
});

router.get('/current', function(req, res, next) {
    res.status(200).json({"test":req.session.test});
})

设置变量似乎有效...

/set API 调用应设置一个名为 test 的 session 变量。当我使用 curl 尝试时,此 API 调用似乎有效:

curl -X GET localhost:3000/api/projects/set --cookie "connect.sid=s%3AyP3a8siRuA-5jDxWH4T03UxNpFd6lfBq.Ha8b8eJxbtW8fAJlbgR9jumfmBpJIXNE6444fOb2Jro"
{"test":"test"}

这也在控制台日志中得到证实:

Session {
  cookie: 
   { path: '/',
     _expires: null,
     originalMaxAge: null,
     httpOnly: true },
  test: 'test' }

...但是下次我检查它时它没有设置

当我尝试使用第二个 API 调用检查变量时,它似乎未声明:

curl -X GET localhost:3000/api/projects/current --cookie "connect.sid=s%3AyP3a8siRuA-5jDxWH4T03UxNpFd6lfBq.Ha8b8eJxbtW8fAJlbgR9jumfmBpJIXNE6444fOb2Jro"
{}

这在控制台日志中得到确认,不再设置 test 变量:

Session {
  cookie: 
   { path: '/',
     _expires: null,
     originalMaxAge: null,
     httpOnly: true } }

如何确保我的 session 变量在请求中持续存在?

(PS:我已经在这个问题上停留了一段时间,任何有关提示或解决方案的小评论都是非常受欢迎的,即使您不确定自己是否得到了答案)

最佳答案

我认为有两个可能的原因。

<小时/>

首先,您可能搞乱了 curl 中的 cookie。

您可以通过检查 http 响应来确保您已正确设置 cookie。如果它包含带有新 connect.sidSet-Cookie header ,那么您做错了什么。

或者,您可以使用支持 native cookie 的网络浏览器来防止此类错误。

<小时/>

其次,您可能在两个请求之间重新启动了服务器。

由于您没有为 session 指定任何持久存储,因此在 Node.js 服务器重新启动之间不会保留任何数据。

如果您希望 session 数据在 Node.js 服务器停止或重新启动后保留,您应该考虑使用一些持久 session 存储(即 redis-store)。

关于javascript - Express session 变量不会跨请求持续存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34663198/

相关文章:

javascript - Redis 流式处理 LIST 响应

javascript - 在浏览器中自动完成 ="off"强制

javascript - 使用Ajax和Nodejs更新页面上的数据

javascript - 一屏显示图片的CSS/Javascript框架

javascript - 在嵌套调用中使用 clearInterval

javascript - Symbol.Iterator - 传递参数

javascript - 返回 Mongodb 查询 Distinct

linux - 安装 gulp browserify 总是报错

javascript - 如何从 node.js Controller 渲染 .ejs 文件?

json - 纯文本到 JSON