Goji 没有返回 404——任何来自 Goji 的 404 都应该由Logger
中间件记录到控制台(stdout)。向 Goji 路由器传递请求的上游处理程序正在反弹任何不是/api/list
.
您可以通过更宽松的匹配来解决此问题:
package main
import (
"fmt"
"net/http"
"github.com/zenazn/goji/web"
"github.com/zenazn/goji/web/middleware"
)
func main() {
mux := web.New()
http.Handle("/api/", mux)
mux.Use(middleware.EnvInit)
mux.Use(middleware.Logger)
mux.Get("/api/list/:id", debugHandler)
mux.Get("/api/list", debugHandler)
mux.Post("/api/list", debugHandler)
// If Goji's router 404's, we should call our custom handler, and it
// should also be apparent in the logs.
mux.NotFound(notFoundHandler)
http.ListenAndServe(":8000", nil)
}
func debugHandler(c web.C, w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "%v\n", r.URL.Path)
}
func notFoundHandler(c web.C, w http.ResponseWriter, r *http.Request) {
http.Error(w, fmt.Sprintf("Goji 404: %s", r.URL.Path), 404)
}
请注意,我已更改上游http.Handle
以http.Handle("/api/", mux)
提供更宽松的匹配。net/http
路由器非常简单,因为(例如,带有 id)在它甚至命中您创建的 Goji mux 实例之前与它/api/list/131313
不匹配404。/api/list
希望有帮助。