我有这个功能来验证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 Token结构中的Valid属性检查它是否有效。但是,当我运行Web服务器时,我在第13行收到错误,说:
Mixed named and unnamed function parameters
第13行是jwt.ParseFromRequest()调用。对我做错了什么的想法?我是Go的新手。
答案 0 :(得分:3)
token, err := jwt.ParseFromRequest(r, func(token *jwt.Token) (interface{}, err error)
此处的函数返回两个参数,一个接口和错误。
您需要像( x interface{}, err error )
或
您需要命名为( interface{}, error )
,因为
您现在拥有的是两个错误类型参数的参数列表。
就像你说:
var x, y, z int
你有一个整数列表,你写道你有两个逗号分隔的变量,类型错误名为interface{}
和err
。编译器知道interface{}
是一个错误变量的愚蠢名称,并且指出你需要一个变量用于第一个(它假定的是真正的a)类型,或者你应该抛弃单词err
答案 1 :(得分:1)
您正在定义一个内联函数(类型为jwt.Keyfunc
),但不会将其绑定到任何内容。如果VerifyKey
的类型为jwt.Keyfunc,则可以将第13行更改为
token, err := jwt.ParseFromRequest(r, VerifyKey)