我有一个使用Angular和Node(Nest JS)的应用程序,在服务器端我使用快速会话。 在我的中间件中,我将登录的用户添加到会话中:
req.session.user = user;
当用户尝试使用Iphone登录时,他无法登录。在重新编译问题之后,我发现每个请求都有不同的sessionId。 我可以看到,在我在会话中对用户进行inlitialze之后它工作正常,但是下一个请求是空的(没有用户对象)并且有一个新的id。
此问题仅在IOS中发生。
我确实尝试更改快速会话选项:maxAge,httpOnly,resave,saveUninitialized,没有任何效果。
这些是我的明确定义:
app.then(instance => {
instance.use(compress({
filter: function ( req, res ) {
return (/json|text|javascript|css|font|svg/).test(res.getHeader('Content-Type'));
},
level: 9
}))
if ( _.has(config, 'log.format') ) {
instance.use(morgan(':method :url :status :res[content-length] - :response-time ms', Logger.getMorganOptions()));
}
instance.use(bodyParser.json());
instance.use(bodyParser.urlencoded({extended: true}));
instance.use(cookieParser(config.sessionSecret));
var MemoryStore = require('memorystore')(session);
instance.use(session({
store: new MemoryStore({
checkPeriod: 86400000 // prune expired entries every 24h
}),
saveUninitialized: true,
resave: true,
secret: config.sessionSecret,
cookie: {
maxAge: null,
httpOnly: false,
},
name: config.sessionKey,
}));
var corsOptions = {
origin: function ( origin, callback ) {
var isWhitelisted = originsWhitelist.indexOf(origin) !== -1;
callback(null, isWhitelisted);
},
credentials: true,
};
instance.use(cors(corsOptions));
instance.listen(3000, () =>
console.log('Application is listening on port 3000')
)
});