Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah Saya Boleh Log Respons HTTP dengan Berkesan dalam Go?
Melog Respons HTTP Menggunakan Go
Permintaan log masuk dalam Go adalah mudah dengan pakej seperti mux dan pengendali Gorilla. Walau bagaimanapun, respons pengelogan boleh menjadi lebih rumit. Artikel ini meneroka cara untuk mencapainya.
Menggunakan Pengendali Pengelogan Tersuai
Satu penyelesaian ialah mencipta pengendali pengelogan tersuai yang membungkus fungsi pengendali HTTP. Kod Eric Broda di bawah menyediakan rangka kerja awal:
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)) } }
Mengubah suai Respons
Untuk menghantar respons kepada pelanggan, pengubahsuaian pada kod diperlukan:
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) } }
Kod yang diubah suai ini membungkus fungsi pengendali dan merekodkan kedua-dua permintaan dan badan tindak balas. Dengan meletakkan pengendali pengelogan ini dalam tindanan middleware, anda boleh log respons dengan mudah sepanjang aplikasi anda.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Log Respons HTTP dengan Berkesan dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!