在NodeJs http请求中传递cookie

时间:2014-06-23 12:11:09

标签: javascript node.js cookies

我是NodeJs的新手。我正在尝试发出http请求并传递cookie。我已经阅读了有关它的stackoverflow上的所有线程,并编写了一段理论上应该工作的代码。但是,它没有。

我要做的是将带有商店代码的cookie发送到一个在线商店,该商店将向我显示有关这个商店的信息。如果没有cookie,则会显示要求选择商店的默认div

这是我的代码:

var request = require('request'),
    http = require('follow-redirects').http,
    request = request.defaults({
        jar: true
    });

var cookieString = 'MC_STORE_ID=66860; expires=' + new Date(new Date().getTime() + 86409000);
var str = '';
//var uri = 'example.de';

//var j = request.jar();
var cookie = request.cookie(cookieString);
j.setCookie(cookie, uri);

var options = {
    hostname: 'example.de',
    path: '/pathexample',
    method: 'GET',
    headers: {
        'User-Agent': 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11',
            'Cookie': cookie,
            'Accept': '/',
            'Connection': 'keep-alive'
    }
    //,jar: j
};

http.request(options, function (resp) {
    resp.setEncoding('utf8');
    console.log(resp.headers);
    if (resp.statusCode) {
        resp.on('data', function (part) {
            str += part;
        });
        resp.on('end', function (part) {
            console.log(str);
        });

        resp.on('error', function (e) {
            console.log('Problem with request: ' + e.message);
        });
    }
}).end(str);

我认为我的请求会发送和接受cookie,但事实并非如此。我也试过jar。我在代码中对它进行了评论。但是,它似乎也不适合我。当我console.log(resp.headers)时,我会看到原始的cookie,但不是我的。有人能给我一个暗示吗?

cookie结构是正确的。当我在谷歌浏览器控制台中运行document.cookie=cookie;时,它就会被替换掉。

5 个答案:

答案 0 :(得分:16)

在你的标题中尝试直接放入cookieString

headers: {
    'User-Agent': 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11',
    'Cookie': cookieString,
    'Accept': '/',
    'Connection': 'keep-alive'
}

答案 1 :(得分:13)

我有同样的问题,@ Ricardo帮助我弄明白。 我从标题

中删除了 jar
//Set the cookie instead of setting into header
var cookie = request.cookie('MC_STORE_ID=66860');


// Set the headers for the request
var headers = {
    'Content-Type': 'application/json',
    'Content-Length': Buffer.byteLength(post_data),
    'Cookie': cookie
};
// Configure the request
var options = {
    url: requestObj["URL"],
    method: 'POST',
    headers: headers
};

// Start the request
request(options, function (error, response, body) {
    if (!error && response.statusCode === 200) {
        // Print out the response body
        cb(null, {status: 0, statusDsc: "success", data: body});
    } else {
        cb(error, {status: 2, statusDsc: JSON.stringify(error)});
    }
});

这是您的Cookie数据与我的请求功能之间的混合。

答案 2 :(得分:3)

不幸的是,这两个答案对我都不起作用。我将重复一遍,目的是通过传递包含商店代码的cookie来发出http请求。要获取此分支的页面HTML,而不是要求我选择一个的标准页面。 尝试了两个选项后,我没有收到任何错误,但它也没有将cookie传递给网站。 但非常感谢Subject为我提供的功能。它给了我一个想法,使用这些和提供的标头与JSDOM。所以这里的代码对我有用:

var jsdom = require('jsdom');

var stores = ["68357"];

function dataCookieToString(dataCookie) {
    var t = "";
    for (var x = 0; x < dataCookie.length; x++) {
        t += ((t !== "") ? "; " : "") + dataCookie[x].key + "=" + dataCookie[x].value;
    }
    return t;
}

function mkdataCookie(cookie) {
    var t, j;
    cookie = cookie.toString().replace(/,([^ ])/g, ",[12],$1").split(",[12],");
    for (var x = 0; x < cookie.length; x++) {
        cookie[x] = cookie[x].split("; ");
        j = cookie[x][0].split("=");
        t = {
            key: j[0],
            value: j[1]
        };
        for (var i = 1; i < cookie[x].length; i++) {
            j = cookie[x][i].split("=");
            t[j[0]] = j[1];
        }
        cookie[x] = t;
    }
    return cookie;
}

var dataCookie = mkdataCookie('MC_STORE_ID=' + stores[0] + '; Expires=' + new Date(new Date().getTime() + 86409000));

jsdom.env({
    url: 'http://www.example.de',
    headers: {
        'User-Agent': "NodeJS/1.0",
            'Cookie': dataCookieToString(dataCookie)
    },
    scripts: ['http://code.jquery.com/jquery-1.5.min.js'],
    done: function (err, window) {
        var $ = window.jQuery;
        console.log($('body').html());
    }
});

这个cookie设置为succsessfuly,我得到了我想要的这个分支的网页源代码。 感谢您的回答,并希望它能帮助其他人。

答案 3 :(得分:2)

您的变量 cookieString Set-Cookie 标头。它是服务器发送给客户端的服务器头,但不是客户端发送给服务器的cookie。

Set-Cookie 标题:

 MC_STORE_ID=66860; expires=1234;

客户端发送 Cookie 标题:

 MC_STORE_ID=66860;

尝试以下功能:

function dataCookieToString(dataCookie) {
    var t = "";
    for (var x = 0; x < dataCookie.length; x++) {
        t += ((t != "") ? "; " : "") + dataCookie[x].key + "=" + dataCookie[x].value;
    }
    return t;
}

function mkdataCookie(cookie) {
    var t, j;
    cookie = cookie.toString().replace(/,([^ ])/g, ",[12],$1").split(",[12],");
    for (var x = 0; x < cookie.length; x++) {
        cookie[x] = cookie[x].split("; ");
        j = cookie[x][0].split("=");
        t = {
            key: j[0],
            value: j[1]
        };
        for (var i = 1; i < cookie[x].length; i++) {
            j = cookie[x][i].split("=");
            t[j[0]] = j[1];
        }
        cookie[x] = t;
    }

    return cookie;
}

开始使用它:

dataCookie = mkdataCookie('MC_STORE_ID=66860; expires=' + new Date(new Date().getTime() + 86409000));
// or mkdataCookie(resp.headers["set-cookie"]) in your `http.request.end()` function.

mkdataCookie返回一个对象。

然后你可以在标题中设置它:

headers: {
    "User-Agent": "NodeJS/1.0",
    "Cookie": dataCookieToString(dataCookie)
}

答案 4 :(得分:0)

要从Cookie数组(来自响应的set-cookie标头)转换为请求Cookie:

    headers: {
     'cookie':cookies.map(c=>c.substr(0, c.indexOf(";"))).reduce((a, b) => a + "; " + b)
}