首页 > 后端开发 > Golang > 在 Go 中使用 `http.FileServer` 提供静态文件时如何记录 404 错误?

在 Go 中使用 `http.FileServer` 提供静态文件时如何记录 404 错误?

DDD
发布: 2024-10-31 01:42:29
原创
1044 人浏览过

How can I log 404 errors when using `http.FileServer` to serve static files in Go?

记录 Http.FileServer 的 404 错误

使用 http.FileServer 提供静态文件时,记录何时对不存在的文件发出请求通常很重要存在。虽然 http.FileServer 本身不提供此类日志记录,但扩展其功能可以让您实现此目标。

要包装 http.StripPrefix 和 http.FileServer 返回的处理程序,请创建一个新的 http.Handler 或 http.Handler。处理函数。包装器将调用包装的处理程序并检查生成的 HTTP 响应状态代码。如果它指示错误(特别是 HTTP 404 Not Found),它可以记录该事件。

由于 http.ResponseWriter 不支持读取响应状态代码,请为其创建一个包装器 (StatusRespWr)。这个包装器会在写入时存储状态码。

http.Handler 包装器的代码如下所示:

<code class="go">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)
        }
    }
}</code>
登录后复制

main 函数可以创建文件服务器,包装它,并注册它:

<code class="go">http.HandleFunc("/o/", wrapHandler(
    http.StripPrefix("/o", http.FileServer(http.Dir("/test")))))
panic(http.ListenAndServe(":8181", nil))</code>
登录后复制

请求不存在的文件时,控制台会生成以下输出:

2015/12/01 11:47:40 Error status code: 404 when serving path: /o/sub/b.txt2
登录后复制

以上是在 Go 中使用 `http.FileServer` 提供静态文件时如何记录 404 错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板