使用 http.FileServer 提供静态文件时,记录何时对不存在的文件发出请求通常很重要存在。虽然 http.FileServer 本身不提供此类日志记录,但扩展其功能可以让您实现此目标。
要包装 http.StripPrefix 和 http.FileServer 返回的处理程序,请创建一个新的 http.Handler 或 http.Handler。处理函数。包装器将调用包装的处理程序并检查生成的 HTTP 响应状态代码。如果它指示错误(特别是 HTTP 404 Not Found),它可以记录该事件。
由于 http.ResponseWriter 不支持读取响应状态代码,请为其创建一个包装器 (StatusRespWr)。这个包装器将在写入时存储状态代码。
http.Handler 包装器的代码如下所示:
func wrapHandler(h http.Handler) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
srw := &StatusRespWr{ResponseWriter: w}
h.ServeHTTP(srw, r)
if srw.status >= 400 { // 400 codes are error codes
log.Printf("Error status code: %d when serving path: %s",
srw.status, r.RequestURI)
}
}
}
main函数可以创建文件服务器,包装它,并注册它:
http.HandleFunc("/o/", wrapHandler(
http.StripPrefix("/o", http.FileServer(http.Dir("/test")))))
panic(http.ListenAndServe(":8181", nil))
当请求不存在的文件时,控制台会生成以下输出:
2015/12/01 11:47:40 Error status code: 404 when serving path: /o/sub/b.txt2
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3