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(); });
- 如何用摩卡上传文件进行unit testing
- Nodejs套接字挂断&ECONNRESET – 从meteor到Node js服务器的HTTP post请求
- ExpressJS:是否可以在不同路由function之间共享相同路由的variables?
- Shopify。 用shopify-node-api更新元字段时出现问题
- 关于nodejs server.listen()
- 用Vows和Tobi进行Webapptesting
- 分离Express.js服务器和客户端项目
- urlencoded与Node.Js中的表单数据
- 如何在centos 6.4 virtualbox客户端上用express来设置和configurationnode.js到nginx反向代理?