golang は nmap を実装します
Golang は、効率的で信頼性の高いネットワーク アプリケーションの構築に適したプログラミング言語です。 Nmap は、ネットワーク検出とセキュリティ監査に使用される一般的なツールで、ネットワーク上のホストを迅速に検出し、そのオペレーティング システムとサービスのオープン ポートを特定します。この記事では、Golang を使用して簡単な nmap ツールを実装する方法を紹介します。
開始する前に、Golang と nmap をインストールする必要があります。
- Golang プロジェクトの作成
コマンド ラインに次のコマンドを入力して、新しい Golang プロジェクトを作成します:
mkdir nmap cd nmap go mod init github.com/yourusername/nmap
このコマンドは、次の内容を含むプロジェクトを作成します。 go.mod
ファイル プロジェクト、go.mod
ファイルはプロジェクトの依存関係を管理するために使用されます。
- nmap ライブラリのインポート
次のコマンドを使用して、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 サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...

この記事では、go.modを介してGOモジュールの依存関係の管理、仕様、更新、競合解決をカバーすることについて説明します。セマンティックバージョンや定期的な更新などのベストプラクティスを強調しています。

Beegoormフレームワークでは、モデルに関連付けられているデータベースを指定する方法は?多くのBEEGOプロジェクトでは、複数のデータベースを同時に操作する必要があります。 Beegoを使用する場合...
