TLS错误:socket在nodejs中挂起

时间:2013-11-20 09:31:53

标签: node.js sockets ubuntu ssl

我正在尝试使用nodejs中的tls连接服务器。这是我的代码:

var options = {
  rejectUnauthorized: false //self signed certificate
};
co = require("tls").connect(5200, "my_host", options, function(){
   co.on("data", function(data) {
      //do domething
   })

}

这是简化的代码。如果我发现了错误事件,我会遇到ECONNRESET错误,如果我没有,我会得到这样的跟踪:

Error: socket hang up
at SecurePair.error (tls.js:1001:23)
at EncryptedStream.CryptoStream._done (tls.js:697:22)
at EncryptedStream.read [as _read] (tls.js:493:12)
at EncryptedStream.Readable.read (_stream_readable.js:320:10)
at CleartextStream.onCryptoStreamFinish (tls.js:301:47)
at CleartextStream.g (events.js:175:14)
at CleartextStream.EventEmitter.emit (events.js:92:17)
at finishMaybe (_stream_writable.js:354:12)
at endWritable (_stream_writable.js:361:3)
at CleartextStream.Writable.end (_stream_writable.js:339:5)

如果我使用openssl s_client -connect my_host:5200直接连接到我的服务器,那么效果很好。奇怪的是,节点版本为0.10。*,它可以在ubuntu 10.04上运行,但在我的mac上也不适用于ubuntu 12.04。我的服务器也是运行ubuntu 10.04的nodejs程序。不确定所有这些是否相关,但任何帮助都会很棒! 干杯

1 个答案:

答案 0 :(得分:-1)

根据客户端/服务器的运行情况,此处可能存在时间问题。您希望在回调之外设置事件处理程序,以确保在数据流动之前设置它们。试试这个:

var options = {
  rejectUnauthorized: false //self signed certificate
};
co = require("tls").connect(5200, "my_host", options, function(){
  //do something
});

co.on("data", function(data) {
  //do something
});