Linux 基礎教程 28-nc命令

来源:https://www.cnblogs.com/surpassme/archive/2018/07/25/9368484.html
-Advertisement-
Play Games

nc     nc命名netcat,直譯為 網路貓 。在CentOS 7查看幫助的解釋如下所示: 翻譯過來就是可以連接和重定向Sockets。通過查詢其他資料,可以看到nc命令功能確實非常多,它可以打開TCP連接,發送UDP包,監聽TCP/UDP埠,進行埠掃描等等。 基本語法 ...


nc

    nc命名netcat,直譯為網路貓。在CentOS 7查看幫助的解釋如下所示:

ncat - Concatenate and redirect sockets

翻譯過來就是可以連接和重定向Sockets。通過查詢其他資料,可以看到nc命令功能確實非常多,它可以打開TCP連接,發送UDP包,監聽TCP/UDP埠,進行埠掃描等等。

基本語法

nc [選項] [主機名] [埠]

常用參數如下所示:

參數 說明
-4 僅使用IPv4
-6 僅使用IPv6
-c,--sh-exec [command] 執行給定的命令,同/bin/sh
-e,--exec [command] 執行給定的命令
-m,--max-conns [n] 設置同時連接的最大數
-d,--delay [time] 設置讀/寫的等待時間
-o,--output [filename] 將會話的數據保存為文件
-i,--idle-timeout [time] 讀/寫空閑超時時間
-p,--source-port port 指定本機使用的通信埠
-s,--source addr 指定遠程通信的主機地址
-l,--listen 監聽傳入的連接信息
-k,--keep-open 在監聽模式中接收多個連接信息
-n,--nodns 直接使用IP地址,不解析功能變數名稱
-t,--telnet 響應telnet請求
-u,--udp 使用UDP替換預設的TCP
-v,--verbose 顯示詳細的輸出信息
-w,--wait [time] 設置連接超時時間,單位為秒
-z 建立連接後馬上斷開,不發送和接收任何數據,即Zero-I/O模式,僅用於測試連接狀態

示例

1.實現QQ的功能

  • 在本地終端監聽一個埠
nc -l 9999
  • 在另一臺伺服器中輸入以下命令建立連接
  nc 連接伺服器IP 9999
  • 在任何一個伺服器上輸入的信息都將發送到另一臺伺服器上面

2.埠掃描

    在Linux中雖然有專業的埠掃描埠工具,如nmap,但如果我們只想知道埠是否處理開放狀態,nc命令其實也是可以勝任的。下麵演示就是掃描本機埠20-25

[root@localhost ~]# nc -z -v -n -w 2 127.0.0.1 20-25
nc: connect to 127.0.0.1 port 20 (tcp) failed: Connection refused
nc: connect to 127.0.0.1 port 21 (tcp) failed: Connection refused
Connection to 127.0.0.1 22 port [tcp/*] succeeded!
nc: connect to 127.0.0.1 port 23 (tcp) failed: Connection refused
nc: connect to 127.0.0.1 port 24 (tcp) failed: Connection refused
Connection to 127.0.0.1 25 port [tcp/*] succeeded!

    當連接到伺服器上的某個埠時,監聽該埠的服務會傳送一個Banner(類似於一條歡迎消息)信息,這個Banner一般都會顯示自身程式的版本號等信息。而黑客就要可以利用這些信息做入侵策略。從上面我們可以看到22埠處於開放狀態,因此我們就可以獲取埠22的Banner信息

[root@localhost ~]# nc -v 127.1 22
Ncat: Version 7.50 ( https://nmap.org/ncat )
Ncat: Connected to 127.0.0.1:22.
SSH-2.0-OpenSSH_7.4

    從上面信息可以看到SSH的版本,如果這個版本的SSH有漏洞的話,就可以被黑客給利用了。

3.傳輸文件

    在Linux傳輸文件,通常使用FTP和SCP,為什麼還需要使用nc命令了?其實nc命令傳輸文件有其獨有的優勢,即只需要選擇一個埠就可以在兩台伺服器間傳輸文件,而不需要進行任何配置,也不需要像FTP和SCP那樣驗證用戶名和密碼等信息。

  • 在文件的發送端,啟動監聽埠並準備好相應的文件
nc -v -l 9999 < out.txt
  • 在文件的接收端,使用以下命令接收數據
[root@localhost ~]# nc -v -n 伺服器IP地址 9999 > in.txt
[root@localhost ~]#  ll in.txt
-rw-r--r-- 1 root root 25 7月  23 00:08 in.txt
  • 此時在發送端可以看到如下信息
[root@localhost ~]# nc -v -l 9999 < out.txt 
Connection from 客戶端IP地址 port 9999 [tcp/distinct] accepted

4.傳輸文件夾

    如果需要傳輸多個文件或文件夾,nc是不是就無法完成了?這時就需要使用tar命令了。

  • 使用管道技術,將tar的輸出通過管道傳給nc
[root@localhost~]# tar -cvPf - ~/out | nc -l 9999
/root/out/
/root/out/out.txt
/root/out/eip.sh
  • 在客戶端連接9999埠,然後將接收到數據通過tar解壓
[root@localhost ~]# nc -n 伺服器IP地址 9999 | tar -xvPf -
/root/out/
/root/out/out.txt
/root/out/eip.sh

本文同步在微信訂閱號上發佈,如各位小伙伴們喜歡我的文章,也可以關註我的微信訂閱號:woaitest,或掃描下麵的二維碼添加關註:
MyQRCode.jpg


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 0.簡介 Abp 框架在其內部實現了倉儲模式,並且支持 EF Core 與 Dapper 來進行資料庫連接與管理,你可以很方便地通過註入通用倉儲來操作你的數據,而不需要你自己來為每一個實體定義單獨的倉儲的實現,通用倉儲包含了常用的 CRUD 介面和一些常用方法。 例如: 1.通用倉儲定義與實現 在 ...
  • 在IIS上部署web api 完成後,瀏覽時出現了“The compiler failed with error code -2146232576.”的錯誤(有時會出現這個情況)。主要是 我們在.Net Framework 下創建Web API的時候,選擇預設的模板後,VS在創建項目時會添加一些組件 ...
  • 實際開發中有很多項目需要引用第三方的dll或者資源文件,且文件比較多,在運行時這些文件需要被拷貝到BIN目錄。 使用VS自帶的"複製到輸出目錄",似然方便,但是比較不零活,經過多次摸索,終於有了一個很好的解決辦法。 將csproj中copy指令的用法如下: 1、記事本打開啟動項目的 csproj文件 ...
  • 線程概述 線程是一個獨立處理的執行路徑。每個線程都運行在一個操作系統進程中,這個進程是程式執行的獨立環境。在單線程中進程的獨立環境內只有一個線程運行,所以該線程具有獨立使用進程資源的權利。在多線程程式中,在進程中有多個線程運行,所以它們共用同一個執行環境。 基礎線程(thread) 使用Thread ...
  • 基於 Red Hat Enterprise Linux 7.5 或者 CentOS 7.4 基本概念 Linux最核心的一個概念就是:Linux裡面任何東西都可以被視為一個文件,包括系統本身(說到底Linux啟動不就是調用那些開機文件再連帶啟動其他的文件麽~~~) User:文件擁有者 Group: ...
  • 什麼是shell? shell是一個命令解釋器,它在操作系統的最外層,負責直接與用戶對話,把用戶的輸入解釋給操作系統,並處理各種各樣的操作系統的輸出結果,輸出到屏幕返回給用戶。這種對話方式可以是交互的方式(從鍵盤輸入命令,可以立即得到shell的回應),或非交互(執行腳本程式)的方式。下圖的黃色部分... ...
  • Linux幫助文檔 1、--help 一般是Linux命令自帶的幫助信息 如:ls --help 2、man man是linux提供的一個手冊,包含了絕大多數的命令、函數使用說明 該手冊分成許多章節(section),使用man時可以指定不同的章節來瀏覽。 例:man ls; man 2 print ...
  • linux的設計之處就是為了多用戶同時執行不同的任務,但是硬體資源是有限的,不能讓一個用戶無限制的上傳文件,如果不加以限制,那麼磁碟最終將會被充滿,對此我們應該使用uquota來加以限制。 1.quota分類 1.1 軟限制:當達到限制時,提示用戶,但任然允許用戶在限定的額度內使用磁碟 1.2 硬限 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...