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