Cas*_*337 1 rest http backend go mux
我正在做一个小演示,试图解释一个基本的 HTTP 处理程序是如何工作的,我发现了以下示例:
package main
func router() *mux.Router {
router := mux.NewRouter()
auth := router.PathPrefix("/auth").Subrouter()
auth.Use(auth.ValidateToken)
auth.HandleFunc("/api", middleware.ApiHandler).Methods("GET")
return router
}
func main() {
r := router()
http.ListenAndServe(":8080", r)
}
Run Code Online (Sandbox Code Playgroud)
package auth
func ValidateToken(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
var header = r.Header.Get("secret-access-token")
json.NewEncoder(w).Encode(r)
header = strings.TrimSpace(header)
if header == "" {
w.WriteHeader(http.StatusForbidden)
json.NewEncoder(w).Encode("Missing auth token")
return
}
if header != "SecretValue" {
w.WriteHeader(http.StatusForbidden)
json.NewEncoder(w).Encode("Auth token is invalid")
return
}
json.NewEncoder(w).Encode(fmt.Sprintf("Token found. Value %s", header))
next.ServeHTTP(w, r)
})
}
Run Code Online (Sandbox Code Playgroud)
package middleware
func ApiHandler(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusOK)
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode("SUCCESS!")
return
}
Run Code Online (Sandbox Code Playgroud)
一切都是可以理解的,但我脑海中突然冒出两个问题:
secure.Use(auth.ValidateToken)?auth.ValidateTokenfunc发送一个额外的参数,(例如,一个字符串,应该比较这个头而不是"SecretValue"),这怎么做?提前致谢,我对使用 golang 有点陌生,想了解更多。
auth.Use将函数作为参数,并且auth.ValidateToken是您传递的函数。如果您想向 发送一个参数auth.ValidateToken,您可以编写一个接受该参数的函数,并返回一个中间件函数,如下所示:
func GetValidateTokenFunc(headerName string) func(http.Handler) http.Handler {
return func(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
var header = r.Header.Get(headerName)
...
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后你可以这样做:
auth.Use(auth.GetValidateTokenFunc("headerName"))
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
568 次 |
| 最近记录: |