Can I send a GET request with cookies in the headers in Node?

In a browser, if I send a GET request, the request will send the cookie in the meanwhile. Now I want to simulate a GET request from Node, then how to write the code?

Here is Solutions:

We have many solutions to this problem, But we recommend you to use the first solution because it is tested & true solution that will 100% work for you.

Solution 1

Using the marvelous request library cookies are enabled by default. You can send your own like so (taken from the Github page):

var j = request.jar()
var cookie = request.cookie('your_cookie_here')
request({url: '', jar: j}, function () {

Solution 2

If you want to do it with the native http:request() method, you need to set the appropriate Set-Cookie headers (see an HTTP reference for what they should look like) in the headers member of the options argument; there are no specific methods in the native code for dealing with cookies. Refer to the source code in Mikeal’s request library and or the cookieParser code in connect if you need concrete examples.

But Femi is almost certainly right: dealing with cookies is full of rather nitpicky details and you’re almost always going to be better off using code that’s already been written and, more importantly, tested. If you try to reinvent this particular wheel, you’re likely to come up with code that seems to work most of the time, but occasionally and unpredicatably fails mysteriously.

Solution 3

var jar = request.jar();
const jwtSecret = fs.readFileSync(`${__dirname}/.ssh/id_rsa`, 'utf8');
const token = jwt.sign(jwtPayload, jwtSecret, settings);
jar.setCookie(`any-name=${token}`, 'http://localhost:12345/');
const options = {
  method: 'GET',
  url: 'http://localhost:12345',
  json: true
request(options, handleResponse);

Note: Use and implement solution 1 because this method fully tested our system.
Thank you 🙂

All methods was sourced from or, is licensed under cc by-sa 2.5, cc by-sa 3.0 and cc by-sa 4.0

Leave a Reply