本文讨论了一种获取 HTTP 响应以进行日志记录的替代方法,而无需诉诸伪造请求或修改 http.ResponseWriter。我们引入了中间件链接的概念,提供了函数式实现。
中间件链接涉及将控制权传递给处理程序链,这些处理程序在主请求执行之前和之后执行特定任务。这些处理程序(称为中间件)接收请求和链中的下一个处理程序,确保有序执行。
我们定义一个充当 HTTP 处理程序组合器的自定义中间件函数:
func NewResponseLoggingHandler(next http.HandlerFunc) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
// Replace the response writer with a recorder for subsequent handlers
c := httptest.NewRecorder()
next(c, r)
// Copy data from the recorder to the original response writer
for k, v := range c.HeaderMap {
w.Header()[k] = v
}
w.WriteHeader(c.Code)
c.Body.WriteTo(w)
}
}
为了确保特定类别中所有处理程序的自动响应日志记录,我们创建另一个封装日志记录中间件的处理程序组合器:
func NewDefaultHandler(next http.HandlerFunc) http.HandlerFunc {
return NewResponseLoggingHandler(NewOtherStuffHandler(next))
}
现在,使用 NewDefaultHandler 实例化的任何处理程序链都将自动包含响应日志记录和其他默认行为。
h := NewDefaultHandler(...)
使用中间件链接,我们可以透明地拦截和记录 HTTP 响应,而不需要伪造请求或修改 http.ResponseWriter。这种方法允许模块化日志记录并简化处理程序管理。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3