在典型場景中,我們會遇到儲存在文字檔案中的HTTP 請求和回應的管道。當我們需要將這些管道訊息解析為結構化格式以進行分析或進一步處理時,就會出現挑戰。本文將引導您完成在 Go 中解析來自此類文字檔案的 HTTP 請求和回應的步驟。
Go 標準函式庫提供了一個方便的函數 http.ReadRequest,這簡化了 HTTP 請求的解析。它從 *bufio.Reader 讀取請求行、標頭和正文(如果由 Content-Length 標頭指定)。
req, err := http.ReadRequest(buf) if err != nil { return err }
http.ReadResponse 函式執行HTTP 回應的類似任務。它從 *bufio.Reader 讀取狀態行、標頭和正文。
resp, err := http.ReadResponse(buf, req) if err != nil { return err }
http.ReadResponse 函數在傳回時自動關閉回應正文。為了保留正文以供以後使用,我們需要手動將其複製到另一個緩衝區。
b := new(bytes.Buffer) io.Copy(b, resp.Body) resp.Body.Close() resp.Body = ioutil.NopCloser(b)
要從檔案解析 HTTP 管道,我們使用 bufio 套件逐行讀取檔案並建立一個 Connection 結構體切片來儲存解析後的請求和回應。
stream := make([]Connection, 0) for { req, err := http.ReadRequest(buf) if err == io.EOF { break } resp, err := http.ReadResponse(buf, req) if err != nil { return err } ... stream = append(stream, Connection{Request: req, Response: resp}) }
出於驗證目的,我們可以使用 httputil.DumpRequest 和 httputil.DumpResponse 將解析後的請求和回應轉儲到字串中進行檢查。
b, err := httputil.DumpRequest(c.Request, true) if err != nil { log.Fatal(err) } fmt.Println(string(b)) b, err = httputil.DumpResponse(c.Response, true) if err != nil { log.Fatal(err) } fmt.Println(string(b))
透過利用 http.ReadRequest 和 http.ReadResponse 函數以及仔細的正文處理,我們可以有效地解析 Go 中文字檔案中的 HTTP 管道請求和回應。這種方法使我們能夠以方便可靠的方式分析、處理或測試 HTTP 通訊場景。
以上是如何在 Go 中解析來自文字檔案的管道化 HTTP 請求和回應?的詳細內容。更多資訊請關注PHP中文網其他相關文章!