Consignation des données HTTP ResponseWriter
Dans Go, la journalisation simultanée des données de requête et de réponse peut s'avérer difficile. Pour résoudre ce problème, envisagez d'utiliser io.MultiWriter, qui duplique toutes les écritures sur plusieurs rédacteurs.
<code class="go">func api1(w http.ResponseWriter, req *http.Request) { var log bytes.Buffer rsp := io.MultiWriter(w, &log) // From this point onward, use rsp instead of w ... }</code>
Avec cette configuration, rsp duplique les écritures à la fois sur w (l'auteur de la réponse) et sur le tampon de journal. Le contenu du tampon de journal peut ensuite être capturé à des fins de journalisation.
Une autre option consiste à utiliser io.TeeReader pour dupliquer les lectures du corps de la requête. Cela garantit que la charge utile de la requête est également enregistrée.
<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>
Dans ce scénario, json.Decoder lit à partir de tee, copiant efficacement le corps de la requête dans le tampon de journal.
En implémentant ces techniques , vous pouvez rédiger des journaux significatifs qui capturent à la fois les données de demande et de réponse, fournissant ainsi des informations précieuses à des fins de dépannage et de débogage.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!