13

我需要监听 Linux 嵌入式盒子内的一些任意端口。我选择了 6660 端口,因为无论如何它都是用于未加密的连接,而且由于 Linux 机器运行定制的 Linux 操作系统,因此打开的端口并不多。我发现 netcat(命令行上的 nc)将是最简单和最好的解决方案,因此我不必为此目的开始编写一些 C 程序。

我设法掌握了命令和选项,并实现了从另一台 PC 上收听纯文本的最简单方法,如下所示:

sven@sven:~$ nc 192.168.4.110 6660
sven@sven:~$ hello there!
anotherUser@userg:~$ nc -l -p 6660
anotherUser@userg:~$ hello there!

但实际情况是 netcat 工具随该 Linux 机器上的 busybox 包一起提供。而且我不确定如何监听端口(例如 6660)的语法是什么。我总是得到相同的对话框:

~ # nc -l -p 6660
BusyBox v1.17.1 (Debian 1:1.17.1-8) multi-call binary.
Usage: nc [IPADDR PORT]    
Open a pipe to IP:PORT

此外,我尝试了许多其他方式来实现聆听,但无法完成。我认为至少它会给我任何选择?还

nc -h

或者

nc --help

不要给出任何“减号”选项

但是将文本从 Linux 嵌入式框发送到我的 PC 可以:

~ # nc 192.168.4.130 6660
fsdf
tere
^C
~ #
sven@sven:~$ nc -l -p 6660
fsdf
tere

Linux 嵌入式盒子在同一本地网络内具有功能齐全的网络连接,并具有现有的 eth0 和 lo 链接

eth0      Link encap:Ethernet  HWaddr D0:E3:47:00:03:5F  
          inet addr:192.168.4.179  Bcast:192.168.4.255  Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:28046281 errors:0 dropped:0 overruns:0 frame:0
          TX packets:428464 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:2458890234 (2.2 GiB)  TX bytes:83021395 (79.1 MiB)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:2282 errors:0 dropped:0 overruns:0 frame:0
          TX packets:2282 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:444956 (434.5 KiB)  TX bytes:444956 (434.5 KiB)

Töövõite!

4

1 回答 1

22

这是busybox nc implementation 的手册页

正确的语法是

nc -l -p <port>

我认为,问题是您的busybox版本是在没有nc监听功能的情况下编译的。实际上,在构建时有一个配置选项NC_SERVER,需要启用该选项才能打开该功能。

您能否构建另一个nc,也许从这个版本,并将二进制文件复制到您的嵌入式主机上?您可能需要构建一个交叉编译器环境。

于 2012-03-14T16:53:02.807 回答