Renewing Cookie-session for express.js

2019-07-16 13:40发布

问题:

I'm using the cookie-session module for Expresss.js to deal with sessions.

I would like the sessions to be renewed on every page load (or ajax call). That's how they usually work anywhere.

The documentation doesn't say a word about it.

I've tried doing this, but without success:

app.use(function(req,res,next ){
     req.sessionOptions.maxAge = 20*1000;
     return next();
});

回答1:

I suspect that you are not sending the response cookie to the client. I solved the same problem (using express and cookie-session) with a middleware that sends a cookie containing a different value for each get:

app.use(session({
  key: cookieKey,
  secret: cookieSecret,
  maxAge: 1 * 60 * 60 * 1000 // 1 hour (rolling)
  })
);

app.get('*', function(req, res, next) {
  // To update the session expiration time we need to send the new
  // expiration in the response cookie.
  // To send again the response cookie to the client we need to
  // update the session object.
  req.session.fake = Date.now();
  next();
});

Indeed, if the session object does not change, cookie-session v. 1.2.0 does not set the Set-Cookie header to send the response cookie to the client.