I am trying to add csrf protection to my react app but I am getting an error Invalid token all the time
import bodyParser from \'body-parser\';
import cookie
You need to:
1. Configure csrf
library on the server. This ensures the library will send the first piece of data attached to the server responses.
2. Use csrf
library on the server to generate the second piece of data and attach it to the server response (e.g. HTML form sent to the client). After this step is completed the server response will carry two pieces of CSRF data.
3. On the client take the second piece of data and insert it into the request you are about to send (e.g. the form you are about to submit).
Step 1
So far only the step (1) has been completed. You asked the csrf
library to send the first piece of data as a cookie. You could have used a better configuration:
app.use(csrf({cookie: {
httpOnly: true,
}}));
It ensures the browser won't allow any JS on the client to touch the first piece of data inside the cookie which is good because there is no legit reason for any script to know what is inside this cookie. Later on, in production and when you use HTTPS, you can optionally add secure: true
to the above configuration to make the server refuse to send this cookie over connections that are not secure.
Step 2
To get the second piece of data call csrfToken()
. The csrf
middleware added another property to Request
object for your convenience so it can be called like this: const secondPiece = req.csrfToken()
. You can put the second piece of data into the server responce in any way or manner you like: into another cookie with an arbitrary name (except for the _csrf
name already taken by the step 1 cookie) or into HTTP header named as you like.
For example this code will put it into another cookie:
res.cookie('XSRF-TOKEN', req.csrfToken());
Step 3
On the client write JS to get the second piece of data and put it into one of the predefined places/locations (inside the request to be sent to the server) where csrf
middleware searches for it by default.