Golang tcp转发 remoteAddr错误

博客围绕Golang tcp转发第一版本展开。该版本以accept获取的Conn里的localAddr为源地址,remoteAddr为目的地址。在win设置代理用edge访问网页时出现报错,推测remoteaddr返回的是转发前真实ip而非目的ip,代码中println、sprintf使用也存在参数问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Golang tcp 转发

第一版本

accept获取的Conn里的localAddr做为源地址,remoteAddr来做为目的地址

// tcpForward
package main

import (
    "fmt"
    "net"
    "os"
)

func TcpForward(port int) {
    lisPort := fmt.Sprint(":", port)
    listen, err := net.Listen("tcp", lisPort)
    if err != nil {
        fmt.Println("fault to listen,err: %s", err.Error())
        os.Exit(1)
    }
    defer listen.Close()
    fmt.Println("listenning now!")
    for {
        fromConn, err := listen.Accept()
        if err != nil {
            fmt.Println("fault,err: %s", err.Error())
            fromConn.Close()
            continue
        }
        go toDial(fromConn)
    }

}

func toDial(fromConn net.Conn) {
    toAddr := fromConn.RemoteAddr()
    toConn, err := net.Dial("tcp", toAddr.String())
    if err != nil {
        fmt.Println("fault,err: %s", err.Error())
        toConn.Close()
    }
    fmt.Println("%s to %s", fromConn.LocalAddr().String(), toConn.RemoteAddr().String())
    go copy(fromConn, toConn, 512)
    go copy(toConn, fromConn, 512)
}

func copy(f, t net.Conn, n int) {
    defer f.Close()
    defer t.Close()

    var buf = make([]byte, n)

    for {
        count, err := f.Read(buf)
        if err != nil {
            fmt.Println("fault,err: %s", err.Error())
            break
        }

        count, err = t.Write(buf[:count])
        if err != nil {
            fmt.Println("fault,err: %s", err.Error())
            break
        }
    }
}

win设置代理,用edge访问网页报错!!!

报错信息:

C:/Go/bin/go.exe build [C:/Users/imcjb/Desktop/egoweb]
成功: 进程退出代码 0.
C:/Users/imcjb/Desktop/egoweb/egoweb.exe  [C:/Users/imcjb/Desktop/egoweb]
Hello World!
C:\Users\imcjb\Desktop\egoweb\egoweb.exe
listenning now!
fault,err: %s dial tcp 127.0.0.1:53391: connectex: No connection could be made because the target machine actively refused it.
panic: runtime error: invalid memory address or nil pointer dereference
[signal 0xc0000005 code=0x0 addr=0x18 pc=0x6154cf]

goroutine 20 [running]:
main.toDial(0x6f4a20, 0xc000092038)
    C:/Users/imcjb/Desktop/egoweb/tcpForward.go:36 +0x3bf
created by main.TcpForward
    C:/Users/imcjb/Desktop/egoweb/tcpForward.go:26 +0x2db
fault,err: %s dial tcp 127.0.0.1:53392: connectex: No connection could be made because the target machine actively refused it.
panic: runtime error: invalid memory address or nil pointer dereference
[signal 0xc0000005 code=0x0 addr=0x18 pc=0x6154cf]

goroutine 19 [running]:
main.toDial(0x6f4a20, 0xc000092030)
    C:/Users/imcjb/Desktop/egoweb/tcpForward.go:36 +0x3bf
created by main.TcpForward
    C:/Users/imcjb/Desktop/egoweb/tcpForward.go:26 +0x2db
错误: 进程退出代码 2.

错误猜测

这里的remoteaddr返回的其实是转发前的真实ip,而非目的ip

代码部分还有一个小问题println、sprintf使用错误,他们的参数是interface{}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值