Linux瑞士军刀—netccat

netccat是一个通过TCP/UDP在网络中进行读写数据工具(命令),被称为“瑞士军刀”,主要用于调试领域、传输领域甚至黑客攻击领域。利用该工具,可以将网络中一端的数据完整的发送至另一台主机终端显示或存储,常见的应用为文件传输、与好友即时通信、传输流媒体或者作为用来验证服务器的独立的客户端。

一、Netcat语法

首先使用nc -h 命令查看功能说明:

nc [-46DdhklnrStUuvzC] [-i 间隔] [-p 源端口]
[-s 源IP地址] [-T 服务类型] [-w 超时时间] [-X 代理协议]
[-x 代理地址[:端口]] [主机名] [端口[s]]
123

关键参数介绍:

  • -4 强制nc只能使用IPv4地址。
  • -6 强制nc只能使用IPv6地址。
  • -h 打印nc帮助信息。
  • -i 间隔 在发送和接收之间指定一个间隔时间。同时会引起连接多个接口时的延迟。
  • -z Zero-I/O mode [used for scanning] netcat使用0-IO,连接成功后立即关闭连接,不进行数据交换
  • -v 指详细输出
  • -n 告诉netcat 不要使用DNS反向查询IP地址的域名

二、Netcat功能举例

nc(netcat)可以打开TCP连接,发送UDP包,监听任意的TCP和UDP端口,扫描端口,处理IPv4和IPv6。nc脚本跟telnet(1)不一样,它把错误信息输出到标准错误输出上而不是输出到标准输出上。

1. 简单聊天

在Server端:

nc -lp 8888
1

此时默认是TCP连接,在本机Localhost监听8888端口。 在Client端:

nc -nv 127.0.0.1 8888
1

测试效果如下: 客户端通过TCP连接到服务器8888端口,发送hello,服务器对其回复ok,之后即可互相通信。

//陈硕简单用法:
//本地服务器监听
nc -l 1234
//客户端
nc localhost 1234
12345

使用ctrl+C(或D)退出

当然也可以通过telnet命令进行测试: telnet localhost 8888

2)如果是测试局域网两台主机的通信时,客户端连接远程Remote主机的IP地址即可。 命令则为:

nc -nv 113.54.154.215 8888
1

3) 为了观察一个TCP的标准连接,也就是三次握手四次挥手的内部实现,我们通过tcpdump进行监测一个完整的连接。 当连接本地服务器回环地址时,使用的是lo网卡。

sudo tcpdump -i lo -n tcp port 8888
1

当连接为远程服务器时,使用的是此时Ubuntu 16.04环境下的ens33网卡。

sudo tcpdump -i ens33 -n tcp port 8888
1

可以清晰的看到三次握手。

2. 端口扫描

端口扫描经常被系统管理员和黑客用来发现在一些机器上开放的端口,帮助他们识别系统中的漏洞。 nc可以运行在TCP或者UDP模式,默认是TCP,-u参数调整为udp. 假定服务器此时开启了端口8888。 客户端对IP地址为113.54.154.215的8880附近相邻10个端口进行TCP扫描。 客户端命令为:

nc -nvz 113.54.154.215 8880-8890
1

测试如下: 2)若采用UDP扫描,则服务器和客户端的命令修改如下: 添加-u选项

服务器:
nc -ulp 8888
客户端:
nc -unvz 113.54.154.215 8880-8890
1234

3. 文件传输

大部分时间中,我们都在试图通过网络或者其他工具传输文件。有很多种方法,比如FTP,SCP,TFTP,NFS等等,但是当你只是需要临时或者一次传输文件,真的值得浪费时间来安装配置一个软件到你的机器上嘛。假设你想要传一个文件test.cpp 从A 到B。A或者B都可以作为服务器或者客户端,

让A作为服务器,B为客户端。将服务器A上的文件下载到客户端B上。 Server:

nc -lp 8888 

Client:

nc -n 113.54.154.215 8888  > test.cc
1

这里我们创建了一个服务器在A上并且重定向netcat的输入为文件test.cpp,那么当任何成功连接到该端口,netcat会发送file的文件内容。 在客户端我们重定向输出到test.cc,故意是两个文件的后缀不同,此时查看文件的大小属性。 此时客户端将网络接收到的数据重定向为test.cc,如果数据不需要则将其重定向到/dev/null即可。 2)当然我们可以将客户端的文件发送给服务器,此时将test.cc上传给服务器。 Server

nc -lp 8888 > test.cc
1

Client

nc -n 113.54.154.215 8888  

此时服务器收到的文件重定向到test.cc,我们可以查看此时服务器的文件: 总之,结合管道的用法,使得nc的功能更加强大,比如可以将一个目录压缩为一个文件,之后通过管道与nc结合,传输该目录。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/221794.html<

(0)
运维的头像运维
上一篇2025-04-15 04:59
下一篇 2025-04-15 05:01

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注