Skip to content

Instantly share code, notes, and snippets.

@samsch
Created January 21, 2021 14:23
Show Gist options
  • Save samsch/3c2c98c415e1d5b15e37a272aa0b77f1 to your computer and use it in GitHub Desktop.
Save samsch/3c2c98c415e1d5b15e37a272aa0b77f1 to your computer and use it in GitHub Desktop.
Express-session isn't saving cookies, or cookie seems to be ignored?

Common issues

Multiple origins

By default, the cookies express-session sets will not work if your server's url isn't the same origin as your front end page where you are making requests from. For example, if you are using Create React App's server on localhost:3000, and your server is running at localhost:8000, cookies won't be saved without extra configuration for CORS.

If you can avoid multiple origins, I recommend doing that. A single origin avoids CORS configuration which tends to be troublesome. Most front end build tools (including Create React App) have options to proxy requests to your backend server. Even better are tools which build your front end to files that can be directly served by your backend (such as using Parcel's watch command).

The CORS configuration will include:

  • Setting SameSite on your cookie options to none.
  • Enabling CORS headers with Access-Control-Allow-Origin set to your front end page origin. (Using *, which is the default with cors() does not allow cookies.)
  • Setting Access-Control-Allow-Credentials in your CORS config.

Missing Proxy Trust

If you are using a proxy in front of your server with express-session, and are using secure cookie flag (and you should always use this in production), you need to configure Express's proxy trust to respect forwarding headers from the proxy. Because proxy trust is effectively disabling a security feature, you need to ensure that your server is only accessible through this proxy, or you will be vulnerable to man-in-the-middle attacks by other people proxying directly.

Cookie options you should expect to use

  • secure. In production, you must always use HTTPS, and always enable the secure flag which stops the cookie from working over HTTP.
  • httpOnly. You must always use this option for session cookies. httpOnly tells the browser the cookie should not be read or writable by JavaScript on the web page, which is the only protection from a class of common XSS attack.
    • Note that not enabling this is effectively similar to using localStorage or sessionStorage, with all the security problems that has.
  • SameSite. When you are using a single domain for your pages and server, you should set SameSite to lax or strict. If you are using multiple origins, you must set it to none. In either case, you must still provide separate CSRF mitigation. Theoretically, lax or strict should provide good CSRF mitigation, but it's better to also have explicit protection.
@Martinpasaribu
Copy link

how can my cookies save in browser chrome if my server and clinet has hosting. how setting session-express?

@Martinpasaribu
Copy link

app.use(session({
secret: process.env.SESS_SECRET,
resave: false,
saveUninitialized: true,
store: store,
cookie: {
secure: 'auto',
httpOnly:'auto',
// sameSite:'None'
}
}));

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment