HTTP リクエストとレスポンス データのログ記録
Go で Web API を開発する場合、受信 HTTP リクエストと送信 HTTP レスポンスの両方をログに記録することが重要です監視とデバッグ用。ただし、デフォルトの http.ResponseWriter インターフェイスには、書き込み後の応答データをキャプチャする便利な方法がありません。
io.MultiWriter を使用した応答データのキャプチャ
解決策の 1 つは、io.MultiWriter 関数を使用して、書き込みを複数の宛先に複製するライターを作成することです。これにより、クライアントに送信しながら応答をログに記録できます。
<code class="go">func api1(w http.ResponseWriter, req *http.Request) { var log bytes.Buffer rsp := io.MultiWriter(w, &log) // Subsequent writes to rsp will be duplicated to both w and log ... }</code>
io.TeeReader を使用したリクエスト データのキャプチャ
受信 HTTP リクエスト本文をキャプチャするにはロギングの場合、io.TeeReader 関数を使用して、元のリクエスト本文から読み取りながら別のバッファに書き込むリーダーを作成できます。
<code class="go">func api1(w http.ResponseWriter, req *http.Request) { var log bytes.Buffer tee := io.TeeReader(req.Body, &log) err := json.NewDecoder(tee).Decode(&requestData) ... }</code>
ロギングのためのリクエスト データとレスポンス データの結合
それぞれのバッファーにキャプチャされたリクエスト データとレスポンス データの両方を 1 つのログ メッセージに結合できるようになりました。
<code class="go">// Assuming we have set up log to be a logger with desired format and output log.Printf("%s %s %d %s %s", req.Method, req.URL.Path, req.Proto, log.BufioReader, log.Bytes())</code>
これらの手法を組み合わせることで、効果的にキャプチャできます。受信 HTTP リクエストと送信 HTTP 応答データの両方をログに記録し、API のトラブルシューティングと監視に貴重な洞察を提供します。
以上がGo API で HTTP リクエストとレスポンス データを効果的に記録するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。