Maison  >  Article  >  développement back-end  >  Comment enregistrer les données de demande et de réponse dans Go ?

Comment enregistrer les données de demande et de réponse dans Go ?

DDD
DDDoriginal
2024-11-06 14:37:02587parcourir

How to Log Both Request and Response Data in Go?

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn