Node.js POST导致代码:'ECONNRESET'

我创build了一个示例将数据发布到rest服务,我发现当我有非ascii或非拉丁字符(请参阅data.firstName)时,使用TEST-REST.js的发布请求将抛出

错误:{[错误:套接字挂断]代码:'ECONNRESET'}。

// TEST-REST.js var http = require('http'); var data = JSON.stringify({ firstName: 'JoaquÌn', }); var options = { host: '127.0.0.1', port: 3000, path: '/users', method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': data.length } }; var req = http.request(options, function(res) { var result = ''; res.on('data', function(chunk) { result += chunk; }); res.on('end', function() { console.log(result); }); }); req.on('error', function(err) { console.log(err); }); req.write(data); req.end(); 

并在我的rest服务,它把我这样的错误:

 SyntaxError: Unexpected end of input Sun Sep 08 2013 23:25:02 GMT-0700 (PDT) - at Object.parse (native) at IncomingMessage.<anonymous> (/Volumes/Data/Program_Data/GitHub/app/node_modules/express/node_modules/connect/lib/middleware/json.js:66:27) info at IncomingMessage.EventEmitter.emit (events.js:92:17) at _stream_readable.js:920:16 : - - - [Mon, 09 Sep 2013 06:25:02 GMT] "POST /users HTTP/1.1" 400 - "-" "-" at process._tickDomainCallback (node.js:459:13) 

如果我将'JoaquÌn'的firstName值replace为'abc',那么一切正常。 我想我失去了一些支持或逃脱,使其工作。

有没有人有任何想法我如何解决这个问题? 我也尝试以下:require('querystring')。escape(model.givenName),它的工作原理,但我不满意。

更新我发现,如果我注释掉:app.use(express.bodyParser());错误消失。

这是节点的问题,而不是expression的问题。 https://github.com/visionmedia/express/issues/1749

解决,改变

'Content-Length':data.length

'Content-Length':Buffer.byteLength(data)

规则

当你想查找string的内容长度时,总是使用Buffer.byteLength()

更新

我们也应该在服务器端正常处理错误,以防止通过添加中间件来处理崩溃。

 app.use(function (error, req, res, next) { if (!error) { next(); } else { console.error(error.stack); res.send(500); } }); 

问题是,如果你不处理这个错误,并保持服务器活着,这个远程崩溃利用可以用于DOS攻击。 但是,您可以处理它并继续,并在发生未处理的exception(这会阻止您以未定义状态运行 – 这是一件非常糟糕的事情)时closures进程。

连接模块处理错误并调用next() ,发送一个消息正文和status = 400 。 在你的服务器代码中,你可以在express.bodyParser()之后加上:

 var exit = function exit() { setTimeout(function () { process.exit(1); }, 0); }; app.use(function (error, req, res, next) { if (error.status === 400) { log.info(error.body); return res.send(400); } log.error(error); exit(); });