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
    +关注

    关注

    87

    文章

    10997

    浏览量

    206799
  • TCP
    TCP
    +关注

    关注

    8

    文章

    1275

    浏览量

    78337
  • NC
    NC
    +关注

    关注

    0

    文章

    19

    浏览量

    13985

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

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

收藏 人收藏

    评论

    相关推荐

    Git命令之本地分支与远程分支关联和解除

    的远程分支被删除了,那么就会出现你无法使用git pull,和git push命令。使用一个例子说明这个场景。 我们可以使用下面的命令查看自己本地分支与与远程分支的关联情况。
    的头像 发表于 12-15 09:27 738次阅读
    Git<b class='flag-5'>命令</b>之本地分支与远程分支关联和解除

    Speos Sensor System(SSS)的使用指南

    本文是Speos Sensor System(SSS)的使用指南,这是一个强大的解决方案,用于camera sensor模拟结果的后处理。本文的目的是通过个例子来理解如何正确使用SSS。当然本文描述的分析步骤适合任何案例。
    的头像 发表于 12-03 09:49 571次阅读
    Speos Sensor System(SSS)的使用指南

    for循环的基本例子

    for循环是一种常见的循环结构,用于重复执行一段代码。它通常由三个部分组成:循环变量的初始化、循环条件和循环变量更新。下面将通过详细的例子来解释for循环的用法和工作原理。 首先,我们来考虑一个简单
    的头像 发表于 11-22 10:00 1036次阅读

    python最简单for循环例子

    。 在Python中,for循环可以用来遍历任何可迭代对象,比如列表、元组、字符串等等。我们可以使用for关键字和in关键字来编写一个简单的for循环。 让我们来看一个例子,假设我们要打印从1到10的数字。我们可以使用一个简单的for循环来实现这个任务。
    的头像 发表于 11-21 14:53 514次阅读

    如何用HLS实现UART呢?

    UART 是一种旧的串行通信机制,但仍在很多平台中使用。它在 HDL 语言中的实现并不棘手,可以被视为本科生的作业。在这里,我将通过个例子来展示在 HLS 中实现它是多么容易和有趣。
    的头像 发表于 11-20 09:50 370次阅读
    如何用HLS实现UART呢?

    如何用HLS实现UART

    UART 是一种旧的串行通信机制,但仍在很多平台中使用。它在 HDL 语言中的实现并不棘手,可以被视为本科生的作业。在这里,我将通过个例子来展示在 HLS 中实现它是多么容易和有趣。
    的头像 发表于 11-20 09:48 315次阅读
    如何用HLS实现UART

    linux中创建group的命令

    在Linux中,创建用户组的命令是 groupadd 。 以下是一个例子: groupadd groupName 这个命令将创建一个新的用户组,名称为groupName。 在创建用户组后,可以
    的头像 发表于 11-08 11:35 669次阅读

    关于三极管的功能验证仿真

    三极管我们怎么用?我们举个例子来说明下各个功能是如何的?先以N管为例;
    的头像 发表于 11-05 17:25 1067次阅读
    关于三极管的功能验证仿真

    零基础学习嵌入式,能学会吗?

    是要学过计算机相关专业的,嵌入式是技术类的知识,有计算机相关知识学习过程中会更加容易上手。 嵌入式定义 嵌入式系统是一种专用的计算机系统,作为装置或设备的一部分,作为一个控制程序存储在ROM中。举个例子来说诸如电视,手
    的头像 发表于 10-13 15:42 287次阅读

    KEIL中如何让程序在RAM中运行

    STM32F411Nucleo 的一个例子来介绍几种让程序在 RAM 中运行的方法。在该例子中,通过调用 ToggleLED 函数来翻转 LED2 亮灭。接下来,我们将通过多种方法将
    发表于 09-28 08:19

    个例子来说明PWM如何输出指定脉冲数

    个例子来说明PWM如何输出指定脉冲数: 假设我们需要使用PWM来控制一个直流电机的转速。电机的转速可以通过调节PWM脉冲的占空比来实现。为了输出指定脉冲数,我们可以将电机连接到PWM控制器的输出
    发表于 09-21 08:55

    PLC MES  真正实战 源程序 视频 报文 结构 ,多个例子,,

    真正实战源程序视频报文结构,多个例子,,
    发表于 09-10 11:09

    如何简化光刻胶图形化过程呢?

    掺杂少量铂元素的镍硅化物的稳定性也不尽相同,还与物质的具体结构有关,举个例子来说,NiPtSi,比NiSi要稳定。
    的头像 发表于 08-27 09:18 694次阅读
    如何简化光刻胶图形化过程呢?

    分享一个非常实用且强大的Linux nc命令

    nc是netcat的简写,是一个功能强大的网络工具,其功能是用于扫描与连接指定端口,有着网络界的瑞士军刀美称。
    的头像 发表于 08-16 09:15 7029次阅读
    分享一个非常实用且强大的Linux <b class='flag-5'>nc</b><b class='flag-5'>命令</b>

    聊聊Rust与C语言交互的具体步骤

    rust FFI 是rust与其他语言互调的桥梁,通过FFI rust 可以有效继承 C 语言的历史资产。本期通过个例子来聊聊rust与 C 语言交互的具体步骤。
    发表于 07-06 11:15 1048次阅读