我正在尝试使用 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.sid
的 Set-Cookie
header ,那么您做错了什么。
或者,您可以使用支持 native cookie 的网络浏览器来防止此类错误。
<小时/>其次,您可能在两个请求之间重新启动了服务器。
由于您没有为 session 指定任何持久存储,因此在 Node.js 服务器重新启动之间不会保留任何数据。
如果您希望 session 数据在 Node.js 服务器停止或重新启动后保留,您应该考虑使用一些持久 session 存储(即 redis-store
)。
关于javascript - Express session 变量不会跨请求持续存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34663198/