我有这个功能来验证 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
}
Run Code Online (Sandbox Code Playgroud)
然后,在我的处理程序中,我调用此函数来获取令牌并使用 JWT 令牌结构中的 Valid 属性检查它是否有效。但是,当我运行 web 服务器时,我在第 13 行收到一个错误,说:
Mixed named and unnamed function parameters
Run Code Online (Sandbox Code Playgroud)
第 13 行是 jwt.ParseFromRequest() 调用。关于我做错了什么的任何想法?我是 Go 的新手。
小智 5
token, err := jwt.ParseFromRequest(r, func(token *jwt.Token) (interface{}, err error)
Run Code Online (Sandbox Code Playgroud)
此处的函数返回两个参数、一个接口和错误。
您需要将两者都命名为 ( x interface{}, err error )
或者
你不需要像这样命名 ( interface{}, error )
因为,
您现在拥有的是两个错误类型参数的参数列表。
就像你说的:
var x, y, z int
Run Code Online (Sandbox Code Playgroud)
您有一个整数列表,您写道您有 2 个逗号分隔的错误类型变量,名为interface{}and err。编译器知道interface{}错误变量是一个愚蠢的名称,并指出您需要一个变量用于第一个(它假定实际上是一个)类型,或者您应该放弃这个词err。
您正在定义一个内联函数(类型为jwt.Keyfunc),但没有将其绑定到任何东西。如果VerifyKey是 jwt.Keyfunc 类型,那么您只需将第 13 行更改为
token, err := jwt.ParseFromRequest(r, VerifyKey)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11188 次 |
| 最近记录: |