我正在尝试捕获并记录在url params未正确编码时发生的http错误400.
我的服务器实现如下:
router := http.NewServeMux()
router.HandleFunc("/", requestHandler)
s := &http.Server{
Addr: ":8080",
Handler: router,
ErrorLog: myLogger,
}
log.Fatal(s.ListenAndServe())
Run Code Online (Sandbox Code Playgroud)
请求永远不会到达requestHandler,并ErrorLog: myLogger没有任何区别.
您需要创建围绕记录的StatusCode并检查它的requestCall已被处理后的requestHandler定制包装.
请注意我们如何包装主路由器本身.同WrapHandler(router)
package main
import (
"log"
"net/http"
)
type LogRecord struct {
http.ResponseWriter
status int
}
func (r *LogRecord) Write(p []byte) (int, error) {
return r.ResponseWriter.Write(p)
}
func (r *LogRecord) WriteHeader(status int) {
r.status = status
r.ResponseWriter.WriteHeader(status)
}
func WrapHandler(f http.Handler) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
record := &LogRecord{
ResponseWriter: w,
}
f.ServeHTTP(record, r)
log.Println("Bad Request ", record.status)
if record.status == http.StatusBadRequest {
log.Println("Bad Request ", r)
}
}
}
func main() {
router := http.NewServeMux()
s := &http.Server{
Addr: ":8080",
Handler: WrapHandler(router),
}
log.Fatal(s.ListenAndServe())
}
Run Code Online (Sandbox Code Playgroud)