Heim >Backend-Entwicklung >Golang >Wie kann ich die SSH-Portweiterleitung in Go implementieren?

Wie kann ich die SSH-Portweiterleitung in Go implementieren?

Barbara Streisand
Barbara StreisandOriginal
2024-11-05 02:12:02862Durchsuche

How can I implement SSH port forwarding in Go?

Einfache SSH-Portweiterleitung in Go

In diesem Artikel befassen wir uns mit der Erstellung und Schließung einer einfachen TCP-Portweiterleitung über SSH Go, speziell für Neueinsteiger in Go und statisch typisierte Sprachen. Wir bieten eine klare und prägnante Lösung, indem wir den Prozess in verständliche Schritte unterteilen.

Hintergrund und Ziel

Unser Ziel ist es, die Funktionalität eines Terminalbefehls wie zu reproduzieren „ssh -L 9000:localhost:9999 Benutzername@Server“ programmgesteuert mit Go. Dieser Befehl richtet eine Portweiterleitung vom lokalen Port 9000 zum Remote-Port 9999 auf dem angegebenen Server ein.

Lösungsübersicht

Um dies zu erreichen, erstellen wir eine lokalen Listener auf Port 9000 und richten Sie eine SSH-Client-Verbindung mit dem Remote-Server ein. Wenn der lokale Port eine Anfrage erhält, stellen wir eine Verbindung zum Remote-Port her und leiten die Daten hin und her.

Code-Aufschlüsselung

<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 forward(localConn net.Conn, config *ssh.ClientConfig) {
    sshClientConn, err := ssh.Dial("tcp", serverAddrString, config)
    if err != nil {
        log.Fatalf("ssh.Dial failed: %s", err)
    }
    sshConn, err := sshClientConn.Dial("tcp", remoteAddrString)
    go func() { _, err = io.Copy(sshConn, localConn) }()
    go func() { _, err = io.Copy(localConn, sshConn) }()
}

func main() {
    config := &ssh.ClientConfig{
        User: username,
        Auth: []ssh.AuthMethod{
            ssh.Password(password),
        },
    }
    localListener, err := net.Listen("tcp", localAddrString)
    if err != nil {
        log.Fatalf("net.Listen failed: %v", err)
    }
    for {
        localConn, err := localListener.Accept()
        if err != nil {
            log.Fatalf("listen.Accept failed: %v", err)
        }
        go forward(localConn, config)
    }
}</code>

Erklärung

  • Wir erstellen einen lokalen Listener auf Port 9000 (localAddrString).
  • Wenn eine Verbindung zum lokalen Port hergestellt wird, stellen wir eine SSH-Client-Verbindung zum Server her (sshClientConn).
  • Wir verbinden uns dann mit dem Remote-Port auf dem Server ( sshConn).
  • Separate Goroutinen werden verwendet, um Daten von der lokalen Verbindung zur SSH-Verbindung und umgekehrt zu kopieren umgekehrt.
  • Dadurch können Daten zwischen den lokalen und Remote-Ports weitergeleitet werden.

Das obige ist der detaillierte Inhalt vonWie kann ich die SSH-Portweiterleitung in Go implementieren?. 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