Heim >Backend-Entwicklung >Golang >Wie implementiert man eine einfache SSH-Portweiterleitung mit Golang?

Wie implementiert man eine einfache SSH-Portweiterleitung mit Golang?

Susan Sarandon
Susan SarandonOriginal
2024-11-05 04:19:02783Durchsuche

How to Implement Simple SSH Port Forwarding Using Golang?

Einfache SSH-Portweiterleitung mithilfe von Golang: Die Komplexität entlarven

Das Erstellen von SSH-Portweiterleitungen in Go kann im Gegensatz zu anfänglichen Annahmen eine unkomplizierte Aufgabe sein . In diesem Artikel möchten wir den Prozess entmystifizieren und ein klares Verständnis dafür vermitteln, wie eine Portweiterleitung in Golang erreicht wird.

Das Konzept verstehen

So richten Sie einen SSH-Port ein Vorwärts müssen wir eine Verbindung zwischen einem lokalen und einem Remote-Port herstellen. Die Daten vom lokalen Port werden über die SSH-Verbindung an den Remote-Port weitergeleitet. Dies ermöglicht einen sicheren Zugriff auf Dienste oder Anwendungen, die auf dem Remote-Computer über den lokalen Port ausgeführt werden.

Implementieren einer einfachen Portweiterleitung

Lassen Sie uns in die Grundlagen eintauchen Portweiterleitung. Hier ist das Schlüsselcode-Snippet, mit dem wir unser Ziel erreichen:

<code class="go">package main

import (
    "io"
    "log"
    "net"
    "golang.org/x/crypto/ssh"
)

var (
    username         = "root"
    password         = "password"
    serverAddrString = "192.168.1.100:22"
    localAddrString  = "localhost:9000"
    remoteAddrString = "localhost:9999"
)

func main() {
    // Configure SSH connection
    config := &ssh.ClientConfig{
        User: username,
        Auth: []ssh.AuthMethod{
            ssh.Password(password),
        },
    }

    // Listen for local port connections
    localListener, err := net.Listen("tcp", localAddrString)
    if err != nil {
        log.Fatalf("net.Listen failed: %v", err)
    }

    for {
        // Accept local port connections
        localConn, err := localListener.Accept()
        if err != nil {
            log.Fatalf("listen.Accept failed: %v", err)
        }

        // Create SSH connection and dial remote port
        sshClientConn, err := ssh.Dial("tcp", serverAddrString, config)
        if err != nil {
            log.Fatalf("ssh.Dial failed: %s", err)
        }

        // Establish remote port connection
        sshConn, err := sshClientConn.Dial("tcp", remoteAddrString)

        // Copy data between local and remote connections
        go func() {
            _, err = io.Copy(sshConn, localConn)
            if err != nil {
                log.Fatalf("io.Copy failed: %v", err)
            }
        }()

        go func() {
            _, err = io.Copy(localConn, sshConn)
            if err != nil {
                log.Fatalf("io.Copy failed: %v", err)
            }
        }()
    }
}</code>

Wie es funktioniert

  1. Lokaler Socket-Listener: Wir initiieren einen Listener auf dem lokalen Port (9000), an dem sich Clientanwendungen zur Portweiterleitung verbinden.
  2. SSH-Verbindungsaufbau: Wenn ein Client eine Verbindung zum lokalen Port herstellt, stellen wir eine SSH-Verbindung zum Remote her Server unter Verwendung des bereitgestellten Benutzernamens und Passworts.
  3. Remote-Socket-Verbindung: Sobald die SSH-Verbindung hergestellt ist, verbinden wir uns mit dem Remote-Port (9999) auf dem Remote-Server.
  4. Datenweiterleitung:Zwischen dem Client und dem Remote-Server wird ein bidirektionaler Datenstrom aufgebaut, der den sicheren Datenaustausch über die SSH-Verbindung ermöglicht.

Schlüssel Punkte

  • Ein lokaler Listener lauscht auf Verbindungen am lokalen Port.
  • Eine SSH-Verbindung wird hergestellt, sobald eine lokale Verbindung wird akzeptiert.
  • Remote-Verbindung stellt eine Verbindung zum Remote-Port auf dem Remote-Server her.
  • Datenweiterleitung kopiert Daten bidirektional zwischen lokal und Remote-Verbindungen.

Dieses Beispiel bietet eine prägnante und leicht verständliche Implementierung der einfachen SSH-Portweiterleitung in Golang. Wenn Sie jeden Schritt des Prozesses verstehen, können Sie die Portweiterleitung effektiv für eine sichere Netzwerkkommunikation nutzen.

Das obige ist der detaillierte Inhalt vonWie implementiert man eine einfache SSH-Portweiterleitung mit Golang?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn