关于linux:Linux之nc命令

4次阅读

共计 3369 个字符,预计需要花费 9 分钟才能阅读完成。

用于设置路由器,是网络工具中的瑞士军刀

nc 命令 全称 netcat,用于设置路由器。它能通过 TCP 和 UDP 在网络中读写数据。通过与其余工具联合和重定向,你能够在脚本中以多种形式应用它。应用 netcat 命令所能实现的事件令人诧异。

Centos 装置nc

> yum -y install nc

Ubuntu 装置nc

> apt-get install netcat

Mac 装置nc

> brew install netcat

命令格局

`nc -hlnruz-G< 指向器数目 >-o< 输入文件 >
-s< 起源位址 >-w< 超时秒数 >[通信端口 …]`

命令选项

  • -g< 网关 > 设置路由器跃程通信网关,最多可设置 8 个。
  • -G< 指向器数目 > 设置起源路由指向器,其数值为 4 的倍数。
  • -h 在线帮忙。
  • -i< 提早秒数 > 设置工夫距离,以便传送信息及扫描通信端口。
  • -l 应用监听模式,管控传入的材料。
  • -n 间接应用 IP 地址,而不通过域名服务器。
  • -o< 输入文件 > 指定文件名称,把往来传输的数据以 16 进制字码倾倒成该文件保留。
  • -p< 通信端口 > 设置本地主机应用的通信端口。
  • -r 乱数指定本地与远端主机的通信端口。
  • -s< 起源位址 > 设置本地主机送出数据包的 IP 地址。
  • -u 应用 UDP 传输协定。
  • -v 显示指令执行过程。
  • -w< 超时秒数 > 设置期待连线的工夫。
  • -z 应用 0 输出 / 输入模式,只在扫描通信端口时应用。

TCP 端口扫描

> nc -v -z  -w2  rumenz.com  20-30
nc: connectx to rumenz.com port 20 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 21 (tcp) failed: Connection refused
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif en0
    src 192.168.0.105 port 57984
    dst 203.195.152.245 port 22
    rank info not available
    TCP aux info available

Connection to rumenz.com port 22 [tcp/ssh] succeeded!
nc: connectx to rumenz.com port 23 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 24 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 25 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 26 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 27 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 28 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 29 (tcp) failed: Connection refused
nc: connectx to rumenz.com port 30 (tcp) failed: Connection refused

20-30是端口范畴

UDP 端口扫描

> nc -v -z -w2 -u rumenz.com 20-25
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif (null)
    src 192.168.0.105 port 63603
    dst 203.195.152.245 port 20
    rank info not available

Connection to rumenz.com port 20 [udp/ftp-data] succeeded!
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif (null)
    src 192.168.0.105 port 51642
    dst 203.195.152.245 port 21
    rank info not available

Connection to rumenz.com port 21 [udp/ftp] succeeded!
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif (null)
    src 192.168.0.105 port 58180
    dst 203.195.152.245 port 22
    rank info not available

Connection to rumenz.com port 22 [udp/ssh] succeeded!
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif (null)
    src 192.168.0.105 port 57409
    dst 203.195.152.245 port 23
    rank info not available

Connection to rumenz.com port 23 [udp/telnet] succeeded!
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif (null)
    src 192.168.0.105 port 59767
    dst 203.195.152.245 port 24
    rank info not available

Connection to rumenz.com port 24 [udp/*] succeeded!
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif (null)
    src 192.168.0.105 port 58696
    dst 203.195.152.245 port 25
    rank info not available

Connection to rumenz.com port 25 [udp/smtp] succeeded!

扫描指定端口

> nc -v json.im 80
found 0 associations
found 1 connections:
     1:    flags=82<CONNECTED,PREFERRED>
    outif en0
    src 192.168.0.105 port 58683
    dst 150.109.147.28 port 80
    rank info not available
    TCP aux info available

Connection to json.im port 80 [tcp/http] succeeded!

建设 C/S 聊天室

nc 的实质是在两台机器之间建设连贯,之后就能够基于这个连贯做很多事件,数据传输是其中一个最为根本的。咱们上面就应用 nc 来建设一个 C/S 的聊天室。

模仿 Server 端

> nc -v -l 127.0.0.1 8086

监听 8086 端口

模仿 Client 端

> nc -v -p 8085 localhost 8086

-p : 指定源端口

连上之后,Client 和 Server 端就能够互相聊天了。

发送文件

nc 不仅能够发送音讯,还可发送文件。

假如服务端有一个 s.txt 的空文件,而客户端有一个 c.txt 文件,含有数据:rumenz.com。

Server 端接管文件

> nc -l 127.0.0.1 8086 > s.txt

Client 端发送文件:

> nc 127.0.0.1 8086 < c.txt

而后 s.txt 就会有 rumenz.com 的数据。除了能够发送文件,nc 也能够发送目录,只须要将目录压缩发送即可。

反对 UDP 和 IPv6 连贯

nc 默认应用 TCP 和 IPv4 协定建设连贯,咱们能够应用参数 -u 和 -6 参数来别离应用建设 UDP 和 IPv6 连贯。

Server 端:

> nc -u -6 -l localhost 8086

Client 端

> nc -u -6 localhost 8086

原文链接:https://rumenz.com/rumenbiji/…
微信公众号: 入门小站

正文完
 0