第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

在 http.HandleFunc 中記錄對(duì)傳入 HTTP 請(qǐng)求的響應(yīng)

在 http.HandleFunc 中記錄對(duì)傳入 HTTP 請(qǐng)求的響應(yīng)

Go
天涯盡頭無(wú)女友 2021-09-27 14:21:15
這是Go中的后續(xù)問(wèn)題,如何檢查寫(xiě)入http.ResponseWriter的http響應(yīng)?因?yàn)槟抢锏慕鉀Q方案需要偽造請(qǐng)求,這對(duì)單元測(cè)試很有用,但不適用于實(shí)時(shí)服務(wù)器。我想將我的 Web 服務(wù)響應(yīng)它從用戶收到的請(qǐng)求而返回的 HTTP 響應(yīng)轉(zhuǎn)儲(chǔ)到日志文件(或控制臺(tái))中。輸出應(yīng)該告訴我標(biāo)頭是什么和 JSON 有效負(fù)載。怎么做呢?如果有一個(gè) httputil.DumpResponse 等價(jià)物將 http.ResponseWriter 作為參數(shù)而不是 http.Response 就完美了,但目前我只能從 http.ResponseWriter 訪問(wèn) Headerr = mux.NewRouter()r.HandleFunc("/path", func (w http.ResponseWriter, r *http.Request) {    fmt.Printf("r.HandleFunc /path\n")    resp := server.NewResponse()    defer resp.Close()    r.ParseForm()    // Server does some work here    // ...    // Insert debug code here, something like    //    // dump = http.DumpResponseFromWriter(w)    // fmt.Printf("%s\n", dump)});http.Handle("/path", r)
查看完整描述

3 回答

?
小怪獸愛(ài)吃肉

TA貢獻(xiàn)1852條經(jīng)驗(yàn) 獲得超1個(gè)贊

中間件鏈

這個(gè)問(wèn)題的一個(gè)常見(jiàn)解決方案是所謂的中間件鏈。有幾個(gè)庫(kù)提供此功能,例如negroni。


這是一種延續(xù)傳遞風(fēng)格的形式,您可以像這樣編寫(xiě)中間件函數(shù)(取自 negroni 的自述文件):


func MyMiddleware(rw http.ResponseWriter, r *http.Request, next http.HandlerFunc) {

  // do some stuff before

  next(rw, r)

  // do some stuff after

}

然后 negroni 為您提供一個(gè) HTTP 處理程序,以正確的順序調(diào)用您的中間件。


我們可以以稍微不同的方式實(shí)現(xiàn)這個(gè)解決方案,而不是一種不太神奇但功能更多的方法(如在函數(shù)式編程中)。定義處理程序組合子如下:


func NewFooHandler(next http.HandlerFunc) http.HandlerFunc {

    return func(w http.ResponseWriter, r *http.Request) {

        // do some stuff before

        next(r,w)

        // do some stuff after

    }

}

然后將您的鏈定義為一個(gè)組合:


h := NewFooHandler(NewBarHandler(NewBazHandler(Sink)))

現(xiàn)在h是http.HandlerFuncfoo,然后是 bar,然后是 baz。Sink只是一個(gè)空的最后一個(gè)處理程序,什么都不做(“完成”鏈。)


將此解決方案應(yīng)用于您的問(wèn)題

定義一個(gè)處理程序組合子:


func NewResponseLoggingHandler(next http.HandlerFunc) http.HandlerFunc {

    return func(w http.ResponseWriter, r *http.Request) {


        // switch out response writer for a recorder

        // for all subsequent handlers

        c := httptest.NewRecorder()

        next(c, r)


        // copy everything from response recorder

        // to actual response writer

        for k, v := range c.HeaderMap {

            w.Header()[k] = v

        }

        w.WriteHeader(c.Code)

        c.Body.WriteTo(w)


    }

}

現(xiàn)在問(wèn)題歸結(jié)為處理程序管理。您可能希望將此處理程序應(yīng)用于某個(gè)類(lèi)別中的所有鏈。為此,您可以再次使用組合器(這在某種程度上相當(dāng)于 negroni 的Classic()方法):


func NewDefaultHandler(next http.HandlerFunc) http.HandlerFunc {

    return NewResponseLoggingHandler(NewOtherStuffHandler(next))

}

在此之后,每當(dāng)您啟動(dòng)這樣的鏈時(shí):


h := NewDefaultHandler(...)

它將自動(dòng)包含響應(yīng)日志記錄和您在NewDefaultHandler.


查看完整回答
反對(duì) 回復(fù) 2021-09-27
  • 3 回答
  • 0 關(guān)注
  • 234 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)