Go에서 요청과 응답 모두 로깅
Go에서 복잡한 애플리케이션을 만들 때 HTTP 요청과 응답을 효율적으로 처리하는 것이 중요합니다. Gorilla 웹 툴킷의 멀티플렉서 및 핸들러 패키지는 요청 처리를 단순화하지만 응답 로깅은 여전히 문제로 남아 있습니다.
이 문제를 해결하기 위해 Eric Broda가 수락한 답변은 요청 세부 정보를 캡처하는 솔루션을 제공합니다. 그러나 클라이언트에 전송된 실제 응답을 기록하지 못합니다. 이 문제를 해결하려면 코드 수정이 필요합니다.
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) } }
이 수정된 코드는 응답을 가로채서 응답 작성기에 복사하여 요청과 응답 모두의 로깅을 활성화합니다.
위 내용은 Go에서 HTTP 요청과 응답을 모두 효율적으로 기록하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!