【发布时间】:2016-07-26 18:33:20
【问题描述】:
我有这个功能用于验证 JWT 令牌(不是中间件),它说:
package main
import (
"net/http"
"log"
"fmt"
"github.com/dgrijalva/jwt-go"
)
func ValidateToken(w http.ResponseWriter, r *http.Request) *jwt.Token {
//parse token
token, err := jwt.ParseFromRequest(r, func(token *jwt.Token) (interface{}, err error) {
return VerifyKey, nil
})
//validate token
if err != nil {
switch err.(type) {
//something went wrong during validation
case *jwt.ValidationError:
vErr := err.(*jwt.ValidationError)
switch vErr.Errors {
case jwt.ValidationErrorExpired:
w.WriteHeader(http.StatusUnauthorized)
fmt.Fprintln(w, "Token expired")
return nil
default:
w.WriteHeader(http.StatusInternalServerError)
fmt.Fprintln(w, "Error parsing token")
log.Printf("Validation error: %v\n", err)
return nil
}
//something else went wrong
default:
w.WriteHeader(http.StatusInternalServerError)
fmt.Fprintln(w, "Error parsing token")
log.Printf("Validation error: %v\n", err)
return nil
}
}
return token
}
然后,在我的处理程序中,我调用此函数来获取令牌并使用 JWT 令牌结构中的 Valid 属性检查它是否有效。但是,当我运行 Web 服务器时,我在第 13 行收到错误消息:
Mixed named and unnamed function parameters
第 13 行是 jwt.ParseFromRequest() 调用。关于我做错了什么有什么想法吗?我是 Go 新手。
【问题讨论】: