Golang は、効率的で信頼性の高いネットワーク アプリケーションの構築に適したプログラミング言語です。 Nmap は、ネットワーク検出とセキュリティ監査に使用される一般的なツールで、ネットワーク上のホストを迅速に検出し、そのオペレーティング システムとサービスのオープン ポートを特定します。この記事では、Golang を使用して簡単な nmap ツールを実装する方法を紹介します。
開始する前に、Golang と nmap をインストールする必要があります。
コマンド ラインに次のコマンドを入力して、新しい Golang プロジェクトを作成します:
mkdir nmap cd nmap go mod init github.com/yourusername/nmap
このコマンドは、次の内容を含むプロジェクトを作成します。 go.mod
ファイル プロジェクト、go.mod
ファイルはプロジェクトの依存関係を管理するために使用されます。
次のコマンドを使用して、nmap ライブラリを go.mod
ファイルに追加します:
require github.com/Ullaakut/nmap/v2 v2.0.0
このコマンドは、Golang に nmap ライブラリのバージョン 2.0.0 を使用するように指示します。 Golang のサポートはバージョン 2.0.0 で追加されました。
次に、nmap スキャンを実装するコードを作成しましょう。プロジェクトのルート ディレクトリに main.go
という名前のファイルを作成し、次のコードを入力します。
package main import ( "fmt" "github.com/Ullaakut/nmap/v2" "log" ) func main() { target := "localhost" ports := "1-1024" // create the scanner scanner, err := nmap.NewScanner( nmap.WithTargets(target), nmap.WithPorts(ports), ) if err != nil { log.Fatalf("unable to create scanner: %v", err) } // run the scan result, warnings, err := scanner.Run() if err != nil { log.Fatalf("unable to run scan: %v", err) } if warnings != nil { log.Printf("warnings: %v", warnings) } for _, host := range result.Hosts { fmt.Printf("IP: %s ", host.Addresses[0]) fmt.Printf("OS: %s ", host.OS.OsMatches[0].Name) fmt.Println("Ports:") for _, port := range host.Ports { if port.State.State == "open" { fmt.Printf("%d/%s %s %s ", port.ID, port.Protocol, port.State.State, port.Service.Name) } } fmt.Println() } }
このコードは、localhost
の最初の 1024 ポートをスキャンし、出力します。各ポートのステータスとサービスを出力します。
コマンド ラインに次のコマンドを入力してコードを実行します。
go run main.go
プログラムはスキャンを実行し、次のような結果が表示されます。
IP: 127.0.0.1 OS: Linux 2.6.x Ports: 22/tcp open ssh 80/tcp open http
この出力は、localhost
のポート 22 と 80 が開いていることを示しています。
結論
Golang と nmap ライブラリを使用して、ネットワーク上のホストを迅速に検出し、そのポートを確認するためのシンプルな nmap ツールを実装しました。 Golang の高速実行性能と nmap ライブラリの使いやすさにより、カスタマイズされたスキャナーの実装が非常に便利です。
以上がgolang は nmap を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。