【发布时间】:2012-05-30 08:31:57
【问题描述】:
我正在向自定义协议 TCP 服务器发出换行符分隔的文本命令。在下面的示例中,我发出 2 个命令并收到回写的响应。它在 telnet 和 netcat 中按预期工作:
$ nc localhost 1234
command1
command2
theresponse
使用 Node.js 连接时,相同的工作流程不起作用:
var net = require('net');
var client = net.connect(1234, 'localhost');
client.on('data', function(data) {
console.log('data:', data.toString());
});
client.on('error', function(err) {
console.log('error:', err.message);
});
client.write('command1\n');
client.write('command2\n');
我希望在运行这个程序后我会看到“数据:响应”写入控制台,但是,什么都没有打印出来。我也尝试过在“连接”回调中执行写入,但结果相同。奇怪的是,当我在 Node REPL 中尝试这个时......它可以工作:
$ node
> var net = require('net')
undefined
> var client = net.connect(1234, 'localhost')
undefined
> client.on('data', function(data) { console.log('data:', data.toString()); })
{ ... }
> client.write('command1\n')
true
> client.write('command2\n')
true
> data: theresponse
有人对这种奇怪的行为有想法吗?
谢谢。
-斯科特
【问题讨论】:
-
根据您的描述,如果两个或多个命令在一个数据包中到达,听起来您的 TCP 服务器会出现问题。你能显示服务器代码吗?
-
我无权访问服务器代码,但我相信您是正确的。服务器可能假设到达的每个“数据”缓冲区都是一个命令。谢谢。
-
我一定遗漏了一些东西,但如果是服务器的错,为什么它在 Node.js REPL 中工作?
-
与它在 Netcat 中工作的原因相同 - 键入下一行需要一点时间。在那段时间里,第一个命令大概被刷新到了服务器。
标签: sockets node.js tcp telnet netcat