Node.js POST导致[错误:套接字挂起]代码:'ECONNRESET'

Nam*_*yen 16 javascript node.js express

我创建了一个将数据发布到休息服务的示例,我发现当我有非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();
Run Code Online (Sandbox Code Playgroud)

在我的休息服务,它给我这样的错误:

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)
Run Code Online (Sandbox Code Playgroud)

如果我将'JoaquÌn'中的firstName值替换为'abc',一切正常.我想我错过了一些支持或逃避的东西让它发挥作用.

有谁知道我是如何解决这个问题的?我也试过以下:require('querystring').escape(model.givenName),它可以工作,但我对它不满意.

UPDATED 我发现如果我注释掉:app.use(express.bodyParser());,错误就会消失.

Nam*_*yen 43

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

解决,改变

'Content-Length':data.length

'Content-Length':Buffer.byteLength(数据)

规则

当您想要查找字符串的内容长度时,请始终使用Buffer.byteLength()

更新

我们还应该优雅地在服务器端处理错误,以防止通过添加中间件来处理它而导致崩溃.

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