【发布时间】:2018-01-01 21:13:36
【问题描述】:
我在 Node 中建立了一个代理服务器,它需要能够通过 tls 传输 https 请求并且一切正常。使用以下两个包非常容易设置:proxy、https-proxy-agent。我的问题是我正在尝试使用connect 作为中间件层来捕获 HAR 文件,但出现以下错误:
_http_outgoing.js:357
throw new Error('Can\'t set headers after they are sent.');
^
Error: Can't set headers after they are sent.
at ServerResponse.OutgoingMessage.setHeader (_http_outgoing.js:357:11)
at ServerResponse.writeHead (_http_server.js:180:21)
at ClientRequest.<anonymous> (/.../node_modules/proxy/proxy.js:233:11)
at emitOne (events.js:96:13)
at ClientRequest.emit (events.js:188:7)
at HTTPParser.parserOnIncomingClient [as onIncoming] (_http_client.js:473:21)
at HTTPParser.parserOnHeadersComplete (_http_common.js:99:23)
at Socket.socketOnData (_http_client.js:362:20)
at emitOne (events.js:96:13)
at Socket.emit (events.js:188:7)
如下所示,它似乎只在我使用connect 并通过我的本地浏览器进行代理时发生(此代理实际上与BrowserStackLocal 一起使用)。当我从本地机器浏览器以外的任何地方通过代理时,就好像它甚至不知道中间件的存在。
所以基本上,我只需要让连接在这种情况下工作,我不确定我是否需要暂停和恢复,或者什么......任何想法将不胜感激。基本代码如下:
const path = require('path');
const http = require('http');
const proxy = require('proxy');
const Agent = require('https-proxy-agent');
const connect = require('connect');
const har = require('./har');
const middleware = connect();
middleware.use(har({
harOutputDir: path.resolve(process.cwd(), 'har/')
}));
const server = proxy(http.createServer(middleware));
server.agent = new Agent('http://localhost:8081');
server.listen(8081)
谢谢!
编辑:请注意:har 中间件根本不修改标头。
【问题讨论】:
-
./har 中间件是否在响应对象上发送数据?如果是这样,将设置一个标题,并且第二个 setHeader 发生错误
-
@Myonara 不——它所做的只是从响应中读取数据,“next()”即使没有“./har”中间件也存在问题。
-
在客户端你能识别,发送的是什么而不是第二个标头答案?
-
@Myonara 我不确定你的意思......似乎连接或代理服务器在对方有机会做任何事情之前正在发送标头。如果我不得不猜测,我会说代理首先发送它的标头,因为它在连接到位时失败。我想知道我是否可以暂停响应并让它等待连接到它的东西。我正在尝试这样做,而无需修改代理并提交 PR。谢谢,迈克
标签: node.js connect http-proxy har