目录
- http库的使用
- Body和GetBody
- URL
- Request.URL.Query
- Request.URL
- Header
- Method
- Form
http库的使用
要实现一个httpServer,首先我们需要先了解一下phpgo语言的原生http库,通常会用到的包括以下几个内容:
- Body和GetBody
- URL
- Method
- Header
- Form
Body和GetBody
Body一般用于获取请求体,但是他有一个问题,因为Body本身是一个流,所以只能读一次,这也就意味着,如果我们有重复读取Body的需要,就必须手动进行处理否则程序会出问题
func readBodyOnce(w http.ResponseWriter, r *http.Request) { body, err := io.ReadAll(r.Body) if err != nil { fmt.Fprintf(w, "read body failed: %v", err) // 记住要返回,不然就还会执行后面的代码 return } // 类型转换,将 []byte 转换为 string fmt.Fprintf(w, "read the data: %s \n", string(body)) // 尝试再次读取,啥也读不到,但是也不会报编程错 body, err = io.ReadAll(r.Body) if err != nil { // 不会进来这里 fmt.Fprintf(w, "read the data one more time got error: %v", err) return } androidfmt.Fprintf(w, "read the data one more time: [%s] and read data length %d \n", string(body), len(body)) }
GetBody原则上是允许重复读取的,但是它会返回一个nil,一般用于处理客户端请求,详情参考官方文档 在服务端处理请求的时候,不建议使用
func getBodyIsNil(w http.ResponseWriter, r *http.Request) { if r.GetBody == nil { fmt.Fprint(w, "GetBody is nil \n") } else { fmt.Fprintf(w, "GetBody not nil \n") } }
URL
Request.URL.Query
用于获取queryParam,所有的值在获取到的时候都是字符串,因此拿到参数后需要自行处理
func queryParams(w http.ResponseWriter, r *http.Request) { values := r.URL.Query() fmt.Fprintf(w,js "query is %v\n", values) }
Request.URL
包含request请求中一些有用的信息,但是不一定都有,实际使用php时需要做一下校验
- Request.URL里的HOST不一定有值
- Request.Host一般有值
- Rawpath也不一定有值
- Path肯定有值
Header
用于获取请求头
func heade开发者_Js入门r(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "header is %v\n", r.Header) }
Method
用于获取请求方法
func method(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "Method is %v\n", r.Method) }
Form
用于处理formData,在使用时要先调用ParseForm,请求头建议加上:Content-Type: application/x-www-form-urlencoded,因为某些原因还无法处理multipart/form-data
到此这篇关于Go语言实现一个Http Server框架(一) http库的使用的文章就介绍到这了,更多相关Go语言 Http Server框架内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
精彩评论