https: use servername
in agent key
https requests with different SNI values should not be sent over the same connection, even if the `host` is the same. Server may want to present different certificate or route the incoming TLS connection differently, depending on the received servername extension. Fix: https://github.com/nodejs/node/issues/3940 PR-URL: https://github.com/nodejs/node/pull/4389 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
This commit is contained in:
parent
29c4a2af5c
commit
3213e5fe6e
@ -130,6 +130,10 @@ Agent.prototype.getName = function(options) {
|
||||
if (options.rejectUnauthorized !== undefined)
|
||||
name += options.rejectUnauthorized;
|
||||
|
||||
name += ':';
|
||||
if (options.servername && options.servername !== options.host)
|
||||
name += options.servername;
|
||||
|
||||
return name;
|
||||
};
|
||||
|
||||
|
52
test/parallel/test-https-agent-sni.js
Normal file
52
test/parallel/test-https-agent-sni.js
Normal file
@ -0,0 +1,52 @@
|
||||
'use strict';
|
||||
const common = require('../common');
|
||||
const assert = require('assert');
|
||||
|
||||
if (!common.hasCrypto) {
|
||||
console.log('1..0 # Skipped: missing crypto');
|
||||
return;
|
||||
}
|
||||
const https = require('https');
|
||||
|
||||
const fs = require('fs');
|
||||
|
||||
const options = {
|
||||
key: fs.readFileSync(common.fixturesDir + '/keys/agent1-key.pem'),
|
||||
cert: fs.readFileSync(common.fixturesDir + '/keys/agent1-cert.pem')
|
||||
};
|
||||
|
||||
const TOTAL = 4;
|
||||
var waiting = TOTAL;
|
||||
|
||||
const server = https.Server(options, function(req, res) {
|
||||
if (--waiting === 0) server.close();
|
||||
|
||||
res.writeHead(200, {
|
||||
'x-sni': req.socket.servername
|
||||
});
|
||||
res.end('hello world');
|
||||
});
|
||||
|
||||
server.listen(common.PORT, function() {
|
||||
function expectResponse(id) {
|
||||
return common.mustCall(function(res) {
|
||||
res.resume();
|
||||
assert.equal(res.headers['x-sni'], 'sni.' + id);
|
||||
});
|
||||
}
|
||||
|
||||
var agent = new https.Agent({
|
||||
maxSockets: 1
|
||||
});
|
||||
for (var j = 0; j < TOTAL; j++) {
|
||||
https.get({
|
||||
agent: agent,
|
||||
|
||||
path: '/',
|
||||
port: common.PORT,
|
||||
host: '127.0.0.1',
|
||||
servername: 'sni.' + j,
|
||||
rejectUnauthorized: false
|
||||
}, expectResponse(j));
|
||||
}
|
||||
});
|
Loading…
x
Reference in New Issue
Block a user