Linux之nc命令

用于设置路由器,是网络工具中的瑞士军刀

nc命令 全称netcat,用于设置路由器。它能通过 TCP 和 UDP 在网络中读写数据。通过与其他工具结合和重定向,你可以在脚本中以多种方式使用它。使用 netcat 命令所能完成的事情令人惊讶。

Centos安装nc

  1. > yum -y install nc

Ubuntu安装nc

  1. > apt-get install netcat

Mac安装nc

  1. > brew install netcat

命令格式

nc [-hlnruz][-g<网关...>][-G<指向器数目>][-i<延迟秒数>][-o<输出文件>][-p<通信端口>] [-s<来源位址>][-v...][-w<超时秒数>][主机名称][通信端口...]

命令选项

  • -g<网关> 设置路由器跃程通信网关,最多可设置8个。
  • -G<指向器数目> 设置来源路由指向器,其数值为4的倍数。
  • -h 在线帮助。
  • -i<延迟秒数> 设置时间间隔,以便传送信息及扫描通信端口。
  • -l 使用监听模式,管控传入的资料。
  • -n 直接使用IP地址,而不通过域名服务器。
  • -o<输出文件> 指定文件名称,把往来传输的数据以16进制字码倾倒成该文件保存。
  • -p<通信端口> 设置本地主机使用的通信端口。
  • -r 乱数指定本地与远端主机的通信端口。
  • -s<来源位址> 设置本地主机送出数据包的IP地址。
  • -u 使用UDP传输协议。
  • -v 显示指令执行过程。
  • -w<超时秒数> 设置等待连线的时间。
  • -z 使用0输入/输出模式,只在扫描通信端口时使用。

TCP端口扫描

  1. > nc -v -z -w2 rumenz.com 20-30
  2. nc: connectx to rumenz.com port 20 (tcp) failed: Connection refused
  3. nc: connectx to rumenz.com port 21 (tcp) failed: Connection refused
  4. found 0 associations
  5. found 1 connections:
  6. 1: flags=82<CONNECTED,PREFERRED>
  7. outif en0
  8. src 192.168.0.105 port 57984
  9. dst 203.195.152.245 port 22
  10. rank info not available
  11. TCP aux info available
  12. Connection to rumenz.com port 22 [tcp/ssh] succeeded!
  13. nc: connectx to rumenz.com port 23 (tcp) failed: Connection refused
  14. nc: connectx to rumenz.com port 24 (tcp) failed: Connection refused
  15. nc: connectx to rumenz.com port 25 (tcp) failed: Connection refused
  16. nc: connectx to rumenz.com port 26 (tcp) failed: Connection refused
  17. nc: connectx to rumenz.com port 27 (tcp) failed: Connection refused
  18. nc: connectx to rumenz.com port 28 (tcp) failed: Connection refused
  19. nc: connectx to rumenz.com port 29 (tcp) failed: Connection refused
  20. nc: connectx to rumenz.com port 30 (tcp) failed: Connection refused

20-30是端口范围

UDP端口扫描

  1. > nc -v -z -w2 -u rumenz.com 20-25
  2. found 0 associations
  3. found 1 connections:
  4. 1: flags=82<CONNECTED,PREFERRED>
  5. outif (null)
  6. src 192.168.0.105 port 63603
  7. dst 203.195.152.245 port 20
  8. rank info not available
  9. Connection to rumenz.com port 20 [udp/ftp-data] succeeded!
  10. found 0 associations
  11. found 1 connections:
  12. 1: flags=82<CONNECTED,PREFERRED>
  13. outif (null)
  14. src 192.168.0.105 port 51642
  15. dst 203.195.152.245 port 21
  16. rank info not available
  17. Connection to rumenz.com port 21 [udp/ftp] succeeded!
  18. found 0 associations
  19. found 1 connections:
  20. 1: flags=82<CONNECTED,PREFERRED>
  21. outif (null)
  22. src 192.168.0.105 port 58180
  23. dst 203.195.152.245 port 22
  24. rank info not available
  25. Connection to rumenz.com port 22 [udp/ssh] succeeded!
  26. found 0 associations
  27. found 1 connections:
  28. 1: flags=82<CONNECTED,PREFERRED>
  29. outif (null)
  30. src 192.168.0.105 port 57409
  31. dst 203.195.152.245 port 23
  32. rank info not available
  33. Connection to rumenz.com port 23 [udp/telnet] succeeded!
  34. found 0 associations
  35. found 1 connections:
  36. 1: flags=82<CONNECTED,PREFERRED>
  37. outif (null)
  38. src 192.168.0.105 port 59767
  39. dst 203.195.152.245 port 24
  40. rank info not available
  41. Connection to rumenz.com port 24 [udp/*] succeeded!
  42. found 0 associations
  43. found 1 connections:
  44. 1: flags=82<CONNECTED,PREFERRED>
  45. outif (null)
  46. src 192.168.0.105 port 58696
  47. dst 203.195.152.245 port 25
  48. rank info not available
  49. Connection to rumenz.com port 25 [udp/smtp] succeeded!

扫描指定端口

  1. > nc -v json.im 80
  2. found 0 associations
  3. found 1 connections:
  4. 1: flags=82<CONNECTED,PREFERRED>
  5. outif en0
  6. src 192.168.0.105 port 58683
  7. dst 150.109.147.28 port 80
  8. rank info not available
  9. TCP aux info available
  10. Connection to json.im port 80 [tcp/http] succeeded!

建立 C/S 聊天室

nc 的本质是在两台机器之间建立连接,之后就可以基于这个连接做很多事情,数据传输是其中一个最为基本的。我们下面就使用 nc 来建立一个 C/S 的聊天室。

模拟 Server 端

  1. > nc -v -l 127.0.0.1 8086

监听8086端口

模拟 Client 端

  1. > nc -v -p 8085 localhost 8086

-p : 指定源端口

连上之后,Client 和 Server 端就可以相互聊天了。

发送文件

nc 不仅可以发送消息,还可发送文件。

假设服务端有一个 s.txt 的空文件,而客户端有一个 c.txt 文件,含有数据:rumenz.com。

Server 端接收文件

  1. > nc -l 127.0.0.1 8086 > s.txt

Client 端发送文件:

  1. > nc 127.0.0.1 8086 < c.txt

然后s.txt就会有rumenz.com的数据。除了可以发送文件,nc 也可以发送目录,只需要将目录压缩发送即可。

支持 UDP 和 IPv6 连接

nc 默认使用 TCP 和 IPv4 协议建立连接,我们可以使用参数 -u 和 -6 参数来分别使用建立 UDP 和 IPv6 连接。

Server 端:

  1. > nc -u -6 -l localhost 8086

Client 端

  1. > nc -u -6 localhost 8086

返回笔记列表
入门小站