主頁 > 知識庫 > go 實現(xiàn)簡易端口掃描的示例

go 實現(xiàn)簡易端口掃描的示例

熱門標(biāo)簽:武漢百應(yīng)人工智能電銷機器人 開通400電話申請流程 揚州電銷外呼系統(tǒng)軟件 百度地圖標(biāo)注位置網(wǎng)站 400手機電話免費辦理 電腦外呼系統(tǒng)輻射大嗎 智能語音電銷的機器人 上海企業(yè)外呼系統(tǒng)排名 如何利用高德地圖標(biāo)注家

我在代碼里定義了兩個通道,分別用于生產(chǎn)端口和限制連接數(shù),如果不限制連接數(shù),容易被對方檢測到或?qū)е聦Ψ椒?wù)器不能正常運行。

// 生產(chǎn)端口
var port = make(chan int, 10)

// 限制并發(fā)數(shù)
var connect = make(chan string, 5)

可以使用net庫的Dial函數(shù)做為socket客戶端,需要注意的是要設(shè)置超時時間,因為若主機不存在,或目標(biāo)端口是關(guān)閉的,往往需要花費數(shù)秒才返回錯誤,這樣掃描大量端口時效率會極其低下。在go中可以使用net.Dialer結(jié)構(gòu)體設(shè)置超時時間,然后在調(diào)用Dial方法:

d := net.Dialer{Timeout: time.Second}
dial, err := d.Dial("tcp", target)

只要err不等于nil,表示目標(biāo)端口是對外開放的。
完整代碼如下:

package main

import (
  "fmt"
  "net"
  "sync"
  "time"
)


var wg sync.WaitGroup

func main() {
  var start, end int
  var address string
  fmt.Printf("請輸入目標(biāo)IP:> ")
  fmt.Scan(address)
  fmt.Printf("請輸入起始端口:> ")
  fmt.Scan(start)
  fmt.Printf("請輸入結(jié)束端口:> ")
  fmt.Scan(end)
  wg.Add(end - start + 1)
  Run(address, start, end)
  wg.Wait()
  fmt.Println("執(zhí)行完畢")
}


// 生產(chǎn)端口
var port = make(chan int, 10)

// 限制并發(fā)數(shù)
var connect = make(chan string, 5)

func Run(address string,  start, end int) {

  go func() {
    for i := start; i = end; i++ {
      port - i
    }
  }()

  go func() {
    // 消費端口
    for p := range port {
      // 往通道寫入目標(biāo)地址,超過限制并發(fā)數(shù)會阻塞
      connect - fmt.Sprintf("%s:%d", address, p)
    }
  }()

  go Connect()


}

func Connect() {
  // 并發(fā)請求
  for target := range connect {
    // 設(shè)置超時時間
    d := net.Dialer{Timeout: time.Second}
    dial, err := d.Dial("tcp", target)
    if err == nil {
      fmt.Printf("%s 連接成功\n", target)
      dial.Close()
    }else{
      fmt.Printf("%s 連接失敗\n", target)
    }
    wg.Done()
  }
}

這里端口生產(chǎn)通道不是必須的,只是為了演示消費生產(chǎn)并發(fā)模型,當(dāng)然這還是最簡單的。
在Run函數(shù)里我沒有關(guān)閉這兩個通道,按官方的說法是gc會回收不使用的通道,如果要手動關(guān)閉,可以定義defer閉包進(jìn)行close。
我本地運行結(jié)果如下:

請輸入目標(biāo)IP:> 127.0.0.1
請輸入起始端口:> 8080
請輸入結(jié)束端口:> 8094
127.0.0.1:8080 連接成功
127.0.0.1:8081 連接成功
127.0.0.1:8082 連接成功
127.0.0.1:8083 連接成功
127.0.0.1:8084 連接成功
127.0.0.1:8085 連接成功
127.0.0.1:8086 連接成功
127.0.0.1:8087 連接成功
127.0.0.1:8088 連接成功
127.0.0.1:8089 連接成功
127.0.0.1:8090 連接成功
127.0.0.1:8091 連接成功
127.0.0.1:8092 連接成功
127.0.0.1:8093 連接失敗
127.0.0.1:8094 連接失敗
執(zhí)行完畢

這個版本比較簡陋,TCP連接過程也可以簡化,后續(xù)再寫另外一篇文章。因為最近在學(xué)rust語言,語法內(nèi)容比較多,所以后面暫時發(fā)布編程相關(guān)的文章,提升一下語法熟練度。

以上就是go 實現(xiàn)簡易端口掃描的示例的詳細(xì)內(nèi)容,更多關(guān)于go 實現(xiàn)端口掃描的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • go xorm框架的使用
  • 解析Go的Waitgroup和鎖的問題
  • Go語言快速入門圖文教程
  • go語言基礎(chǔ) seek光標(biāo)位置os包的使用
  • Go語言獲取文件的名稱、前綴、后綴
  • Go語言 如何實現(xiàn)RSA加密解密
  • Go 自定義package包設(shè)置與導(dǎo)入操作
  • 詳解Gotorch多機定時任務(wù)管理系統(tǒng)

標(biāo)簽:黑龍江 張掖 宜賓 嘉峪關(guān) 武漢 江西 延邊 新余

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《go 實現(xiàn)簡易端口掃描的示例》,本文關(guān)鍵詞  實現(xiàn),簡易,端口,掃描,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《go 實現(xiàn)簡易端口掃描的示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于go 實現(xiàn)簡易端口掃描的示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章