我创建了一个示例来将数据发布到rest服务,并且我发现当我有非ascii或非拉丁字符(请参见data.firstName)时,我使用TEST-REST.js的post请求将抛出
错误:{错误:套接字挂起代码:'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)
如果我将firstName值从‘Joaqu n’替换为'abc',一切都会正常工作。我想我遗漏了一些东西来支持或逃避它的工作。
有人知道我是怎么解决这个问题的吗?我也尝试了如下: require('querystring').escape(model.givenName),,它工作了,但我对它不满意。
更新了我发现如果我注释掉: app.use(express.bodyParser());,错误就会消失。
发布于 2013-09-09 15:26:41
这是node的问题,不是express的问题。https://github.com/visionmedia/express/issues/1749
要解决此问题,请从
内容长度‘
’:data.length
至
内容长度‘
’:Buffer.byteLength(数据)
经验法则
当您想要查找字符串的内容长度时,请始终使用Buffer.byteLength()
已更新
我们还应该在服务器端优雅地处理错误,通过添加中间件来处理它,以防止崩溃。
app.use(function (error, req, res, next) {
if (!error) {
next();
} else {
console.error(error.stack);
res.send(500);
}
});
发布于 2013-09-13 06:35:29
问题是,如果您不处理此错误并保持服务器处于活动状态,则此远程崩溃漏洞可能会被用于DOS攻击。但是,您可以处理它并继续,并在发生未处理的异常时仍然关闭进程(这会阻止您在未定义的状态下运行--这是一件非常糟糕的事情)。
connect模块处理错误并调用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();
});
https://stackoverflow.com/questions/18692580
复制相似问题