Rumah >pembangunan bahagian belakang >Golang >Ejen SSH, panjang paket yang salah

Ejen SSH, panjang paket yang salah

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBke hadapan
2024-02-09 14:00:36991semak imbas

SSH 代理,数据包长度错误

editor php Xinyi hari ini memperkenalkan anda kepada ralat rangkaian biasa - "Proksi SSH, ralat panjang paket". Apabila menggunakan alat ejen SSH, anda kadangkala menghadapi mesej ralat ini, menyebabkan sambungan rangkaian gagal. Ralat ini biasanya disebabkan oleh panjang paket yang ditetapkan secara tidak betul. Dalam artikel ini, kami akan menerangkan punca ralat ini secara terperinci dan menyediakan beberapa penyelesaian untuk menyelesaikan masalah dan memastikan sambungan rangkaian anda lancar.

Kandungan soalan

Melaksanakan proksi ssh dalam go, ralat kerana panjang paket yang salah, ini adalah ralat ssh dalam mod nyahpepijat:

debug1: ssh2_msg_kexinit sent
bad packet length 1231976033.
ssh_dispatch_run_fatal: connection to ::1 port 8080: message authentication code incorrect

Kod:

func handleSSH(conn net.Conn, r *bufio.Reader, protocol string) {

    target, err := url.Parse("ssh://localhost:3333")
    if err != nil {
        fmt.Println("Error parsing target", err)
        conn.Close()
        return
    }

    targetConn, err := net.Dial("tcp", target.Host)
    if err != nil {
        fmt.Println("error dialing SSH target:", err)
        conn.Close()
        return
    }

    defer targetConn.Close()

    var wg sync.WaitGroup
    wg.Add(2)
    go func() {
        _, err := io.Copy(targetConn, conn)
        if err != nil {
            fmt.Println("error copying data to target:", err)
        }
        wg.Done()
    }()

    go func() {
        _, err := io.Copy(conn, targetConn)
        if err != nil {
            fmt.Println("error copying data from target:", err)
        }
        wg.Done()
    }()

    wg.Wait()
    conn.Close()
}

// EDIT

func connection(conn net.Conn) {

    r := bufio.NewReader(conn)
    protocol, err := r.ReadString('\n')
    if err != nil {
        fmt.Println("Error reading first line", err)
        conn.Close()
        return
    }

if protocol[0:3] == "SSH" {
        handleSSH(conn, r, protocol)
    }
}

func main() {
   ln, err := net.Listen("tcp", ":8080")
    if err != nil {
        panic(err)
    }
    defer ln.Close()

    for {
        conn, err := ln.Accept()
        if err != nil {
            panic(err)
        }
        go connection(conn)
    }
}

EDIT: Menambahkan kod dengan maklumat yang berkaitan tentang cara untuk memulakan sambungan dan menghasilkan semula ralat.

Tekaan terbaik saya ialah proses rundingan ssh telah terganggu dan keadaan menjadi tidak segerak.

Penyelesaian

Kod membaca baris pertama dari klien dan menyemak jenis protokol supaya pengendali yang sesuai dipanggil:

protocol, err := r.ReadString('\n')
...
if protocol[0:3] == "SSH" {
        handleSSH(conn, r, protocol)
    }
}

Tetapi kod tidak boleh memajukan bait baca ke pelayan yang disambungkan. Bait ini terletak di protocol 中,并提供给 handlessh. Tetapi setelah sambungan diwujudkan, ia tidak boleh menghantar bait ini ke pelayan yang disambungkan. Sebaliknya, ia hanya menyalin data baharu antara klien dan pelayan.

Ini bermakna pelayan tidak mendapat baris pertama daripada klien. Oleh itu, ia mungkin mengadu tentang ralat protokol seperti invalid ssh id string. yang dimajukan kepada klien dan disalahtafsirkan sebagai data yang sah daripada sambungan ssh.

Atas ialah kandungan terperinci Ejen SSH, panjang paket yang salah. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam