>백엔드 개발 >Golang >Go에서 HTTP 요청과 응답을 효과적으로 기록하려면 어떻게 해야 합니까?

Go에서 HTTP 요청과 응답을 효과적으로 기록하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-05 21:57:12764검색

How Can I Effectively Log Both HTTP Requests and Responses in Go?

HTTP 응답 로깅 개선

HTTP 요청 로깅은 디버깅 및 성능 모니터링의 중요한 측면입니다. 요청 로깅을 위한 Gorilla의 LoggingHandler와 같은 솔루션이 있지만 응답 로깅은 종종 간과되는 작업입니다.

이 문제를 해결하기 위해 응답을 기록하고 클라이언트에 전달하는 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))

        // Forward the response to the client
        for k, v := range rec.HeaderMap {
            w.Header()[k] = v
        }
        w.WriteHeader(rec.Code)
        rec.Body.WriteTo(w)
    }
}

이 수정된 기능은 다음을 달성합니다.

  • 요청을 기록합니다. 이전과 같습니다.
  • 응답을 캡처하기 위해 httptest.NewRecorder를 생성합니다.
  • 응답을 레코더에 기록하는 원래 처리기 함수를 호출합니다.
  • 레코더.
  • 레코더의 헤더와 상태 코드를 실제 응답에 복사합니다. writer.
  • 리코더 본문을 클라이언트에 전달합니다.

이 수정된 기능을 애플리케이션에 통합하면 요청과 응답을 모두 원활하게 기록하여 HTTP에 대한 포괄적인 보기를 제공할 수 있습니다. 소통합니다.

위 내용은 Go에서 HTTP 요청과 응답을 효과적으로 기록하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.