Google Go使用Read()从连接读取EOF



我试图使用谷歌Go语言创建一个简单的TCP服务器。我有一个指向127.0.0.1:8484的客户端。当我的服务器代码试图读取缓冲区时,我在第37行收到EOF错误。客户端发送一个初始tcp数据包,表示其客户端版本和其他设置(客户端来自游戏,因此我知道我做错了什么)。我正在试着读这个包。然而,似乎我调用读取太迟了,客户端已经发送了数据包,正在等待它的响应。如果你能帮助我,我将不胜感激,因为我真的被难住了。

package main
import (
    "fmt"
    "net"
    "os"
)
func main() {
    service := ":8484"
    listener, err := net.Listen("tcp", service)
    checkError(err)
    fmt.Println("Login Server StartednListening on port:", service[1:])
    for {
        conn, err := listener.Accept()
        if err != nil {
            continue
        }
        go handleClient(conn)
    }
}
func handleClient(conn net.Conn) {
    const BUFFER_LENGTH = 1024
    defer conn.Close()
    fmt.Println("Client connected from", conn.RemoteAddr())
    var buf [BUFFER_LENGTH]byte
    for {
        n, err := conn.Read(buf[0:])
        if err != nil {
            checkError(err)
            return
        }
        _, err2 := conn.Write(buf[0:n])
        if err2 != nil {
            checkError(err)
            return
        }
    }
}
func checkError(err error) {
    if err != nil {
        fmt.Fprintf(os.Stderr, "Fatal error: %sn", err.Error())
        os.Exit(1)
    }
}

为清楚起见编辑:1. 客户端连接到服务器。2. 客户端向服务器发送初始信息,例如客户端版本。3.服务器读取缓冲区。4. 服务器响应(目前我只是回显缓冲区)。

当前在读取缓冲区阶段失败"n, err:= conn.Read(buf[0:])".

固定:我是一个白痴,意识到我需要发送一个握手包到客户端。

那么,在checkError中,您执行显式的os.Exit(1),如果客户端出现Read()错误,则终止服务器。

代替:

    n, err := conn.Read(buf[0:])
    if err != nil {
        checkError(err)
        return
    }

你可以做

    n, err := conn.Read(buf[0:])
    if err != nil {
        fmt.Printf(err)
        conn.Close()
        return
    }

这将在服务器端打印错误,并返回监听下一个连接/继续操作。

这适用于我使用nc:

$ nc localhost 8484
Client connected from 127.0.0.1:46464
hello
hello
world
world
^D
Fatal error: EOF
exit status 1

所以我认为你的连接处理没有问题。您可能只是发送了客户端不期望的数据,并因此关闭了连接。

相关内容

最新更新