企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
服务端 ~~~ package main import ( "fmt" "net/http" ) //服务端编写的业务逻辑处理程序 //hander函数: 具有func(w http.ResponseWriter, r *http.Requests)签名的函数 func myHandler(w http.ResponseWriter, r *http.Request) { fmt.Println(r.RemoteAddr, "连接成功") //r.RemoteAddr远程网络地址 fmt.Println("method = ", r.Method) //请求方法 fmt.Println("url = ", r.URL.Path) fmt.Println("header = ", r.Header) fmt.Println("body = ", r.Body) w.Write([]byte("hello go")) //给客户端恢复的数据 } func main() { http.HandleFunc("/go", myHandler) //该方法用于在指定的 TCP 网络地址 addr 进行监听,然后调用服务端处理程序来处理传入的连接请求。 //该方法有两个参数:第一个参数 addr 即监听地址;第二个参数表示服务端处理程序,通常为空 //第二个参数为空意味着服务端调用 http.DefaultServeMux 进行处理 http.ListenAndServe("127.0.0.1:8006", nil) } ~~~ 客户端 ~~~ package main import ( "fmt" "io" "log" "net/http" ) func main() { //get方式请求一个资源 //resp, err := http.Get("http://www.baidu.com") //resp, err := http.Get("http://www.neihan8.com/article/index.html") resp, err := http.Get("http://127.0.0.1:8000/go") if err != nil { log.Println(err) return } defer resp.Body.Close() //关闭 fmt.Println("header = ", resp.Header) fmt.Printf("resp status %s\nstatusCode %d\n", resp.Status, resp.StatusCode) fmt.Printf("body type = %T\n", resp.Body) buf := make([]byte, 2048) //切片缓冲区 var tmp string for { n, err := resp.Body.Read(buf) //读取body包内容 if err != nil && err != io.EOF { fmt.Println(err) return } if n == 0 { fmt.Println("读取内容结束") break } tmp += string(buf[:n]) //累加读取的内容 } fmt.Println("buf = ", string(tmp)) } ~~~