登录
首页 >  Golang >  Go问答

运行curl命令时,遇到TCP服务器的错误信息

来源:stackoverflow

时间:2024-03-04 10:03:28 300浏览 收藏

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《运行curl命令时,遇到TCP服务器的错误信息》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

我编写了一个非常简单的 tcp 服务器,它读取连接并用 hello world 进行响应。

import (
    "fmt"
    "log"
    "net"
)

func handlerequest(conn net.conn) {

    buff := make([]byte, 10)

    _, err := conn.read(buff)

    if err != nil {
        log.fatal(err)
    }

    fmt.println(string(buff))

    conn.write([]byte("hello world"))
    conn.close()
}

func main() {
    ln, err := net.listen("tcp", ":8080")
    fmt.println("listening on port 8080")
    if err != nil {
        log.fatal(err)
    }
    for {
        conn, err := ln.accept()
        if err != nil {
            log.fatal(err)
        }
        go handlerequest(conn)
    }

}

这段代码有什么问题?当我运行curl http://localhost:8080时,我得到这个输出

curl: (56) recv failure: connection reset by peer
hello world%
buff:=make([]byte,1024)

现在,如果我增加缓冲区大小,这段代码可以正常工作,并且在运行curl后我不会收到该错误。

echo -n "Hello" | nc localhost 8080

如果我运行上述命令,它可以正常工作,没有任何问题。

我真的不明白这是什么原因。


解决方案


curl 发送一个较大的 http 请求。尝试打印(或 logconn.read 得到的内容,你就会看到它。 curl 可能会不高兴,因为它没有收到正确的 http 响应。

conn.read 无论如何都不应溢出缓冲区,它会读取缓冲区大小。

另一方面,到 nc 的管道仅在 tcp 套接字上发送 5 个字节。

这是一个与正确 http 进行通信的示例 tcp 服务器:

package main

import (
    "bufio"
    "fmt"
    "log"
    "net"
    "strings"
)

// handleConnection handles a single connected client.
func handleConnection(c net.Conn) {
    defer c.Close()

    scanner := bufio.NewScanner(c)
    // Scan first line for the request
    if !scanner.Scan() {
        log.Fatal(scanner.Err())
    }
    req := scanner.Text()
    for scanner.Scan() {
        // Scan until an empty line is seen
        if len(scanner.Text()) == 0 {
            break
        }
    }
    fmt.Println("req:", req)
    if strings.HasPrefix(req, "GET") {
        rt := fmt.Sprintf("HTTP/1.1 200 Success\r\n")
        rt += fmt.Sprintf("Connection: Close\r\n")
        rt += fmt.Sprintf("Content-Type: text/html\r\n\r\n")
        rt += fmt.Sprintf("Nothing here\r\n")
        c.Write([]byte(rt))
    } else {
        rt := fmt.Sprintf("HTTP/1.1 %v Error Occurred\r\n\r\n", 501)
        c.Write([]byte(rt))
    }
}

func main() {
    l, err := net.Listen("tcp", ":8080")
    if err != nil {
        log.Fatal(err)
    }
    defer l.Close()
    for {
        // Wait for a connection.
        conn, err := l.Accept()
        if err != nil {
            log.Fatal(err)
        }
        go handleConnection(conn)
    }
}

好了,本文到此结束,带大家了解了《运行curl命令时,遇到TCP服务器的错误信息》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>