为什么https.Agent在通过node-http-proxy进行代理时会抛出parsing错误?

我想通过http.Agenthttps.Agent在我的node-http-proxy应用程序中启用连接池的使用。 为此,我build立了一个安全代理,如下所示:

 const secureAgent = new https.secureAgent({ keepAlive: true }); 

(为了简洁起见,我已经补充了互补的http代理。)

我创build一个代理服务器,如下所示:

 const proxy = httpProxy.createProxyServer({}); 

最后,我在Connect中间件中代理请求,如下所示:

 proxy.web(req, res { agent: isSecure ? secureAgent : agent, target: ..., secure: false, }); 

这似乎适用于大多数请求,但每隔几分钟我会看到一个如下所示的错误:

 { "message": "Parse Error", "stack": "Error: Parse Error\n at TLSSocket.socketOnData (_http_client.js:411:20)\n at emitOne (events.js:96:13)\n at TLSSocket.emit (events.js:191:7)\n at readableAddChunk (_stream_readable.js:178:18)\n at TLSSocket.Readable.push (_stream_readable.js:136:10)\n at TLSWrap.onread (net.js:560:20)", "bytesParsed": 215, "code": "HPE_INVALID_CONSTANT", "__error_callsites": [ {}, {}, {}, {}, {}, {} ], "level": "error", "timestamp": "2017-04-18T17:34:09.735Z" } 

从粗略阅读HPE_INVALID_CONSTANT当响应格式HPE_INVALID_CONSTANT时, HPE_INVALID_CONSTANT显现出来了。 但是,直到引入安全代理之前,这些响应才是正确的。

有没有人知道这里发生了什么,或者我可以怎样修复它?

注意:通过FROM node:7.9在Docker容器中的节点v7.9.0上发生此错误。 到目前为止,我只观察到HEAD请求 – 这一定是有原因的。

只需在这里添加评论。 我正面临类似的问题。 (正在使用节点请求库),在我的情况下请求参数中的一个值的空间。 另外我正在向http:// localhost (http)(nginx)发送请求,然后通过pythonredirect到https:// localhost (https)。 这两者的结合给我造成了这个问题。 有一件事我注意到在我的情况下,我有可用的请求主体,但过去分析错误。 我做了一个小黑客来忽略错误,并发送响应。

  let formData = "some data"; let headers = // some headers; headers["content-length"] = formData.length; headers["Accept-Encoding"] = "gzip, deflate"; let gunzip; return new Promise(function (resolve, reject) { let buffer = []; let req = http.request({ port: 80, method: "POST", path: url, headers: headers }, function (res) { let resHeaders = res.headers["content-encoding"]; switch (resHeaders){ case "gzip": gunzip = zlib.createGunzip(); res.pipe(gunzip); gunzip.on("data", function (data) { buffer.push(data.toString()); }).on("end", function () { resolve(buffer[0]) }); break; case "deflate": gunzip = zlib.createDeflate(); res.pipe(gunzip); gunzip.on("data", function (data) { buffer.push(data.toString()); }).on("end", function () { resolve(buffer[0]) }); break; default: res.on("data", function (data) { buffer.push(data.toString()) }).on("end", function () { resolve(buffer[0]) }) } }); req.on('error', (e) => { // This is the Hack. If there is an error just ignore it. logger.debug("Error in getting requests, ", e) }); req.write(formData); req.end(); }) } 

希望能帮助到你。 请分享,如果你找出原因。 我试图找出一天的原因,但不能。 由于我们在生产中有这个问题,所以不得不做这个快速补丁。

从我所知道的情况来看,很可能是因为stream中的HTTPSredirect。