Maison >développement back-end >Golang >Comment puis-je enregistrer efficacement les requêtes et les réponses HTTP dans Go ?
Enregistrement des requêtes et des réponses dans Go
Lors de la création d'une application complexe dans Go, la gestion efficace des requêtes et des réponses HTTP est cruciale. Bien que les packages de multiplexage et de gestion de la boîte à outils Web Gorilla simplifient le traitement des requêtes, la journalisation des réponses reste un défi.
Pour résoudre ce problème, la réponse acceptée par Eric Broda propose une solution qui capture les détails de la requête. Cependant, il ne parvient pas à enregistrer la réponse réelle envoyée au client. Pour résoudre ce problème, une modification du code est nécessaire :
func logHandler(fn http.HandlerFunc) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { x, err := httputil.DumpRequest(r, true) if err != nil { http.Error(w, fmt.Sprint(err), http.StatusInternalServerError) return } log.Println(fmt.Sprintf("%q", x)) rec := httptest.NewRecorder() fn(rec, r) log.Println(fmt.Sprintf("%q", rec.Body)) // this copies the recorded response to the response writer for k, v := range rec.HeaderMap { w.Header()[k] = v } w.WriteHeader(rec.Code) rec.Body.WriteTo(w) } }
Ce code modifié intercepte la réponse et la copie dans l'auteur de la réponse, permettant la journalisation des requêtes et des réponses.
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!