nc

nc是netcat的简写,是一个功能强大的网络工具,有着网络界的瑞士军刀美誉。nc命令在linux系统中实际命令是ncat,nc是软连接到ncat。nc命令的主要作用如下:

  1. 实现任意TCP/UDP端口的侦听,nc可以作为server以TCP或UDP方式侦听指定端口
  2. 机器之间传输文件
  3. 端口的扫描,nc可以作为client发起TCP或UDP连接
  4. 机器之间网络测速

命令格式

nc [-46DdhklnrStUuvzC] [-i interval] [-p source_port]
          [-s source_ip_address] [-T ToS] [-w timeout] [-X proxy_version]
          [-x proxy_address[:port]] [hostname] [port[s]]

命令选项

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

-4                  使用 IPv4
-6                  使用 IPv6
-D                  启用调试套接字选项
-d                  从标准中分离
-h                  此帮助文本
-i secs             发送线路、扫描端口的延迟间隔
-k                  保持入站套接字打开以进行多个连接
-l                  侦听模式,用于入站连接
-n                  禁止显示名称/端口解析
-p port             指定远程连接的本地端口
-r                  随机化远程端口
-S                  启用 TCP MD5 签名选项
-s addr             本地源地址
-T ToS              设置服务的 IP 类型
-C                  将 CRLF 作为行尾发送
-t                  回答远程登录协商
-U                  使用 UNIX 域套接字
-u                  UDP 模式
-v                  显示指令执行过程。
-w secs             连接和最终网络读取超时
-X proto            代理协议:“4”、“5”(SOCKS)或“连接”
-x addr[:port]      指定代理地址和端口
-z                  零 I/O 模式,只在扫描通信端口时使用。

使用实例:

代替telnet

nc 10.36.40.223 22

显示详情

nc -v 10.36.40.223 22

只显示连接状态,不显示数据

nc -z 10.36.40.223 22

在A服务器上启动监听端口

nc -l 8080

在A服务器上启动监听端口,保持入站套接字打开以进行多个连接

nc -l 8080 -k

在B服务器上连接测试

nc 10.36.40.51 8080

监听udp协议

nc -u -l 8080