[英]socket hang up error with nodejs
我想为一些我不是管理员的 XYZ 服务器设置代理。 然后我想对请求和响应标头进行一些分析,然后还要对请求和响应主体进行分析。 所以我使用 http-proxy https://github.com/nodejitsu/node-http-proxy
这就是我正在做的:
var proxy = httpProxy.createProxyServer();
connect.createServer(
connect.bodyParser(),
require('connect-restreamer')(),
function (req, res) {
proxy.web(req, res, { target : 'XYZserver' });
}
).listen(config.listenPort);
到 GET 请求,一切都很好,但是每当发出带有某些正文(如 POST、PATCH、PUT 等请求)的请求时,我都会收到错误消息:
Error: socket hang up
at createHangUpError (http.js:1472:15)
at Socket.socketCloseListener (http.js:1522:23)
at Socket.EventEmitter.emit (events.js:95:17)
at TCP.close (net.js:466:12)
我谷歌了很多,但不知道发生了什么问题。 我使用 'proxy.web' 的 'ws:true' 选项启用了套接字代理,但仍然出现相同的错误。
我有一个类似的问题,并通过将我的代理代码移到其他节点中间件之上来解决它。
例如这个:
var httpProxy = require('http-proxy');
var apiProxy = httpProxy.createProxyServer();
app.use("/someroute", function(req, res) {
apiProxy.web(req, res, { target: 'http://someurl.com'})
});
app.use(someMiddleware);
不是这个:
app.use(someMiddleware);
var httpProxy = require('http-proxy');
var proxy = httpProxy.createProxyServer();
app.use("/someroute", function(req, res) {
proxy.web(req, res, { target: 'http://someurl.com'})
});
我的具体问题是代理上方的 BodyParser 中间件。 我没有做太多挖掘,但它一定以某种方式修改了请求,从而在请求最终到达时破坏了代理库。
只是为了完整起见,正如该线程中所述,模块body-parser
和http-proxy
之间确实存在集成问题。
如果不能改变中间件的顺序; 您可以在代理请求之前重新流式传输解析的正文。
// restream parsed body before proxying
proxy.on('proxyReq', function(proxyReq, req, res, options) {
if (req.body) {
let bodyData = JSON.stringify(req.body);
// incase if content-type is application/x-www-form-urlencoded -> we need to change to application/json
proxyReq.setHeader('Content-Type','application/json');
proxyReq.setHeader('Content-Length', Buffer.byteLength(bodyData));
// stream the content
proxyReq.write(bodyData);
}
}
我已经在这个该死的问题上浪费了 2 天时间。 希望能帮助到你!
需要捕捉代理的错误:
var httpProxy = require('http-proxy');
var proxy = httpProxy.createProxyServer({ target: argv.proxy_url })
proxy.on('error', function(err, req, res) {
res.end();
})
在浪费了一天多的时间并遵循了nodejitsu/node-http-proxy 问题中的一些帖子之后,我能够使其正常工作,这要归功于 riccardo.cardin。 我决定发布完整的示例以节省您的时间。 下面的示例使用 server express 、 body-parser (req.body 中间件)和当然的http-proxy来代理和转发请求到 3rd 方服务器。
const webapitargetUrl = 'https://posttestserver.com/post.php';
var bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json()); // support json encoded bodies
var https = require('https');
var stamproxy = httpProxy.createProxyServer({
target: 'https://localhost:8888',
changeOrigin: true,
agent : https.globalAgent,
toProxy : true,
secure: false,
headers: {
'Content-Type': 'application/json'
}
});
stamproxy.on('proxyReq', function(proxyReq, req, res, options) {
console.log("proxying for",req.url);
if (req.body) {
console.log("prxyReq req.body: ",req.body);
// modify the request. Here i just by removed ip field from the request you can alter body as you want
delete req.body.ip;
let bodyData = JSON.stringify(req.body);
// in case if content-type is application/x-www-form-urlencoded -> we need to change to application/json
proxyReq.setHeader('Content-Type','application/json');
proxyReq.setHeader('Content-Length', Buffer.byteLength(bodyData));
// stream the content
console.log("prxyReq bodyData: ",bodyData);
proxyReq.write(bodyData);
}
console.log('proxy request forwarded succesfully');
});
stamproxy.on('proxyRes', function(proxyRes, req, res){
proxyRes.on('data' , function(dataBuffer){
var data = dataBuffer.toString('utf8');
console.log("This is the data from target server : "+ data);
});
});
app.use(compression());
app.use(favicon(path.join(__dirname, '..', 'static', 'favicon.ico')));
app.use(Express.static(path.join(__dirname, '..', 'static')));
var sessions = require("client-sessions");
app.use(sessions({
secret: 'blargadeeblargblarg',
cookieName: 'mysession'
}));
app.use('/server/setserverip', (req, res) => {
console.log('------------ Server.js /server/setserverip ---------------------------------');
req.mysession.serverip += 1;
console.log('session data:');
console.log(req.mysession.serverip)
console.log('req.body:');
console.log(req.body);
// Proxy forwarding
stamproxy.web(req, res, {target: webapitargetUrl});
console.log('After calling proxy serverip');
});
http-proxy
似乎与body-parser
中间件不兼容。 您可能希望在body-parser
之前移动http-proxy
中间件或停止使用body-parser
。
我在post 、 put和delete 上遇到了这个问题,但是在从chimurai / http-proxy-middleware阅读了这个问题之后,我已经做到了。
1-添加onProxyReq : https : //github.com/chimurai/http-proxy-middleware/issues/40#issuecomment-249430255
2-请注意,您必须将Content-Type: application/json 添加到请求的标头
3- body-parser 没有改变顺序
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.