set-cookies header is an array of values. always
This commit is contained in:
parent
488aff085b
commit
2982e75a0b
33
lib/http.js
33
lib/http.js
@ -235,26 +235,43 @@ IncomingMessage.prototype.resume = function () {
|
|||||||
// and drop the second. Extended header fields (those beginning with 'x-') are
|
// and drop the second. Extended header fields (those beginning with 'x-') are
|
||||||
// always joined.
|
// always joined.
|
||||||
IncomingMessage.prototype._addHeaderLine = function (field, value) {
|
IncomingMessage.prototype._addHeaderLine = function (field, value) {
|
||||||
if (!(field in this.headers)) {
|
|
||||||
this.headers[field] = value;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If this field already exists in the request, use duplicate-resolution
|
|
||||||
// logic from RFC2616.
|
|
||||||
switch (field) {
|
switch (field) {
|
||||||
|
// Array headers:
|
||||||
|
case 'set-cookie':
|
||||||
|
if (field in this.headers) {
|
||||||
|
this.headers[field].push(value);
|
||||||
|
} else {
|
||||||
|
this.headers[field] = [value];
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
// Comma separate. Maybe make these arrays?
|
||||||
case 'accept':
|
case 'accept':
|
||||||
case 'accept-charset':
|
case 'accept-charset':
|
||||||
case 'accept-encoding':
|
case 'accept-encoding':
|
||||||
case 'accept-language':
|
case 'accept-language':
|
||||||
case 'connection':
|
case 'connection':
|
||||||
case 'cookie':
|
case 'cookie':
|
||||||
|
if (field in this.headers) {
|
||||||
this.headers[field] += ', ' + value;
|
this.headers[field] += ', ' + value;
|
||||||
|
} else {
|
||||||
|
this.headers[field] = value;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (field[0] !== 'x' || field[1] !== '-') break;
|
if (field.slice(0,2) == 'x-') {
|
||||||
|
// except for x-
|
||||||
|
if (field in this.headers) {
|
||||||
this.headers[field] += ', ' + value;
|
this.headers[field] += ', ' + value;
|
||||||
|
} else {
|
||||||
|
this.headers[field] = value;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// drop duplicates
|
||||||
|
if (!(field in this.headers)) this.headers[field] = value;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
71
test/simple/test-http-set-cookies.js
Normal file
71
test/simple/test-http-set-cookies.js
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
common = require("../common");
|
||||||
|
assert = common.assert;
|
||||||
|
http = require("http");
|
||||||
|
|
||||||
|
nresponses = 0;
|
||||||
|
|
||||||
|
var server = http.createServer(function(req, res) {
|
||||||
|
if (req.url == '/one') {
|
||||||
|
res.writeHead(200, [ ['set-cookie', 'A'],
|
||||||
|
['content-type', 'text/plain'] ]);
|
||||||
|
res.end("one\n");
|
||||||
|
} else {
|
||||||
|
res.writeHead(200, [ ['set-cookie', 'A'],
|
||||||
|
['set-cookie', 'B'],
|
||||||
|
['content-type', 'text/plain'] ]);
|
||||||
|
res.end("two\n");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
server.listen(common.PORT);
|
||||||
|
|
||||||
|
server.addListener("listening", function() {
|
||||||
|
//
|
||||||
|
// one set-cookie header
|
||||||
|
//
|
||||||
|
var client = http.createClient(common.PORT);
|
||||||
|
var req = client.request('GET', '/one');
|
||||||
|
req.end();
|
||||||
|
|
||||||
|
req.addListener('response', function(res) {
|
||||||
|
// set-cookie headers are always return in an array.
|
||||||
|
// even if there is only one.
|
||||||
|
assert.deepEqual(['A'], res.headers['set-cookie']);
|
||||||
|
assert.equal('text/plain', res.headers['content-type']);
|
||||||
|
|
||||||
|
res.addListener('data', function(chunk) {
|
||||||
|
console.log(chunk.toString());
|
||||||
|
});
|
||||||
|
|
||||||
|
res.addListener('end', function() {
|
||||||
|
if (++nresponses == 2) {
|
||||||
|
server.close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
// two set-cookie headers
|
||||||
|
|
||||||
|
var client = http.createClient(common.PORT);
|
||||||
|
var req = client.request('GET', '/two');
|
||||||
|
req.end();
|
||||||
|
|
||||||
|
req.addListener('response', function(res) {
|
||||||
|
assert.deepEqual(['A', 'B'], res.headers['set-cookie']);
|
||||||
|
assert.equal('text/plain', res.headers['content-type']);
|
||||||
|
|
||||||
|
res.addListener('data', function(chunk) {
|
||||||
|
console.log(chunk.toString());
|
||||||
|
});
|
||||||
|
|
||||||
|
res.addListener('end', function() {
|
||||||
|
if (++nresponses == 2) {
|
||||||
|
server.close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
process.addListener("exit", function () {
|
||||||
|
assert.equal(2, nresponses);
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user