我使用大猩猩mux作为我的路由器,我有一个非常奇怪的行为。在对服务器的第一个请求中,我会得到一个有效的响应。但是在随后的请求中,我会收到一个404 page not found。控制台中没有错误。
我的代码非常简单(可以复制粘贴来测试它):
package main
import (
"fmt"
"github.com/gorilla/mux"
"log"
"net/http"
)
func main() {
router := mux.NewRouter()
router.HandleFunc("/", RootHandler).Name("root")
http.Handle("/", router)
log.Println("Listening on port 1337...")
if err := http.ListenAndServe(":1337", nil); err != nil {
log.Fatal("http.ListenAndServe: ", err)
}
}
func RootHandler(w http.ResponseWriter, r *http.Request) {
content := "Welcome to "
rootUrl, err := mux.CurrentRoute(r).Subrouter().Get("root").URL()
if err != nil {
log.Printf("mux.CurrentRoute(r).Subrouter().Get(\"root\").URL(): ", err)
}
response := content + rootUrl.String()
fmt.Fprintf(w, response)
}经过一些代码注释和测试,下面一行似乎是罪魁祸首:
rootUrl, err := mux.CurrentRoute(r).Subrouter().Get("root").URL()这种使用当前请求在处理程序中获取路由器的方法来自另一个StackOverflow post:How to call a route by its name from inside a handler?
但出于一个奇怪的原因,它只起了一次作用:
shell-1$ go run servertest.go
2014/10/30 13:31:34 Listening on port 1337...
shell-2$ curl http://127.0.0.1:1337
Welcome to /
shell-2$ curl http://127.0.0.1:1337
404 page not found如您所见,控制台中没有错误。
有人知道为什么只工作一次吗?
发布于 2014-10-30 14:07:57
问题是子路由器()不是为了返回路由器,而是为了创建一个路由器,因此它改变了它被调用的路由器的匹配器,使您失去了处理程序。
您可以尝试使用闭包将路由器传递给处理程序。
func RootHandler(router *mux.Router) func(http.ResponseWriter, *http.Request) {
return func(w http.ResponseWriter, r *http.Request) {
...
}
}发布于 2022-12-04 03:51:27
我解决了这个问题,并通过重新启动方法来解决它。
//create a subrouter separately \
subRoute := mux.CurrentRoute(req).Subrouter() \
//Call the Route u want and store the URL
url, err := subRoute.Get("check_authorization").URL("id", key, "password", token)
// re-initiate the method to GET or whatever u had before
subRoute.Methods(http.MethodGet) https://stackoverflow.com/questions/26653152
复制相似问题