> 백엔드 개발 > Golang > 미들웨어 체인 및 기능적 핸들러 결합자를 사용하여 Go\의 `http.HandleFunc`에서 HTTP 응답을 어떻게 기록할 수 있나요?

미들웨어 체인 및 기능적 핸들러 결합자를 사용하여 Go\의 `http.HandleFunc`에서 HTTP 응답을 어떻게 기록할 수 있나요?

Patricia Arquette
풀어 주다: 2024-10-28 04:41:30
원래의
913명이 탐색했습니다.

How can you log HTTP responses in Go's `http.HandleFunc` using middleware chaining and functional handler combinators?

http.HandleFunc

에서 들어오는 HTTP 요청에 대한 응답 로깅

이전 기사에서 "In go, HTTP 검사 방법 http.ResponseWriter에 기록된 응답은 무엇입니까?" 단위 테스트 환경에서 서버 응답을 검사하는 방법을 탐색했습니다. 그러나 이 접근 방식은 라이브 서버에는 적합하지 않을 수 있습니다.

미들웨어 체이닝

대체 솔루션은 HTTP 수정 및 로깅에 일반적으로 사용되는 기술인 미들웨어 체이닝입니다. 원래 요청-응답 흐름을 유지하면서 응답 및 요청을 처리합니다.

함수 처리기 결합기

negroni와 같은 라이브러리를 사용하는 대신 자체 함수 처리기를 만들 수 있습니다. 결합기:

<code class="go">func NewFooHandler(next http.HandlerFunc) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        // do something before
        next(w, r)
        // do something after
    }
}</code>
로그인 후 복사

처리기 체인 만들기

결합기를 사용하여 여러 핸들러를 함께 연결할 수 있습니다:

<code class="go">h := NewFooHandler(NewBarHandler(NewBazHandler(Sink)))</code>
로그인 후 복사

In 이 예에서 싱크는 아무것도 하지 않는 빈 핸들러입니다.

응답 로깅 구현

핸들러 결합자 접근 방식을 사용하면 응답을 기록하는 핸들러를 생성할 수 있습니다. :

<code class="go">func NewResponseLoggingHandler(next http.HandlerFunc) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        // Replace the response writer with a recorder
        c := httptest.NewRecorder()
        next(c, r)

        // Copy the response from the recorder to the actual writer
        for k, v := range c.HeaderMap {
            w.Header()[k] = v
        }
        w.WriteHeader(c.Code)
        c.Body.WriteTo(w)
    }
}</code>
로그인 후 복사

응답 로깅 핸들러 적용

기본 핸들러 조합자를 생성하여 모든 HTTP 경로에 응답 로깅 핸들러를 적용할 수 있습니다.

<code class="go">func NewDefaultHandler(next http.HandlerFunc) http.HandlerFunc {
    return NewResponseLoggingHandler(NewOtherStuffHandler(next))
}</code>
로그인 후 복사

이렇게 하면 다음과 같은 체인을 시작할 때마다

<code class="go">h := NewDefaultHandler(...)</code>
로그인 후 복사

응답 로깅 및 기타 기본 핸들러가 자동으로 포함됩니다.

위 내용은 미들웨어 체인 및 기능적 핸들러 결합자를 사용하여 Go의 `http.HandleFunc`에서 HTTP 응답을 어떻게 기록할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿