gpt4 book ai didi

go - 记录 http 响应(除了请求)

转载 作者:IT王子 更新时间:2023-10-29 00:36:46 26 4
gpt4 key购买 nike

我正在使用 Go 和 Gorilla 网络工具包的 mux 和处理程序包来构建一个复杂的应用程序,其中一部分需要一个 http 服务器。 Gorilla 的 mux 和处理程序包工作得非常好,我能够成功启动并运行 http 服务器,并且记录请求非常简单。

但是,我无法确定如何记录响应。理想情况下,我想要一种类似于 Gorilla 的 LoggingHandler 的机制,它可以轻松地“包装”日志记录机制。

是否有可以轻松包装/记录响应的 Go 包?有没有一种方法可以以我没有考虑过的方式使用 Go 或 Gorilla 的功能?

最佳答案

感谢您的宝贵建议。我尝试了一些建议并找到了一个使用极简包装器的相当简单的解决方案。这是对我有用的解决方案(请随时提供评论,或者更好的是,其他解决方案):

import (
"fmt"
"log"
"net/http"
"net/http/httptest"
"net/http/httputil"
"github.com/gorilla/mux"
)
:

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))
}
}

func MessageHandler(w http.ResponseWriter, r *http.Request) {
fmt.Fprintln(w, "A message was received")
}

下面的代码将使用上述处理程序:

:
router := mux.NewRouter()
router.HandleFunc("/", logHandler(MessageHandler))
:

上述代码的输出类似于:

:
2016/07/20 14:44:29 "GET ... HTTP/1.1\r\nHost: localhost:8088\r\nAccept: */*\r\nUser-Agent: curl/7.43.0\r\n\r\n"
2016/07/20 14:44:29 ...[response body]
:

关于go - 记录 http 响应(除了请求),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38443889/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com