登录
首页 >  Golang >  Go问答

我的JWT自定义代码为什么不能成功执行echo?

来源:stackoverflow

时间:2024-02-06 18:09:22 111浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《我的JWT自定义代码为什么不能成功执行echo?》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

问题内容

我正在使用 echo jwt 验证用户,我在查看手册时进行自定义,但它没有应用。我想要两件事。

  1. 我想在没有不记名关键字的情况下进行令牌检查

  2. 我想返回一条适合未找到令牌或令牌无效的情况的错误消息。

如何修改上面的代码来达到我想要的效果?

我刚刚开始学习 golang,任何建议将不胜感激

output := echojwt.JWT(&echojwt.Config{
        SigningKey:  []byte(key.EnvSecretKey),
        TokenLookup: "header:Authorization",
        ErrorHandler: func(c echo.Context, err error) error {
            if err != nil {
                return c.JSON(400, "custom error")
            }
            return nil
        },
    })

正确答案


以下是您可以遵循的步骤:

  1. 在不使用“bearer”关键字的情况下进行令牌检查:为此,您 可以将 tokenlookup 值从“header:authorization”更改为 “查询:令牌”。这将允许您将令牌作为查询传递 参数而不是在标头中。

  2. 返回适合情况的自定义错误消息 未找到令牌或令牌无效:为此,您可以 修改错误处理函数

这是一个例子:

output := echojwt.JWT(&echojwt.Config{
     SigningKey:  []byte(key.EnvSecretKey),
     TokenLookup: "query:token",
     ErrorHandler: func(c echo.Context, err error) error {
         if err == jwt.ErrTokenNotFound {
             return c.JSON(http.StatusBadRequest, "token not found")
         }
         if ve, ok := err.(*jwt.ValidationError); ok {
             if ve.Errors&jwt.ValidationErrorMalformed != 0 {
                 return c.JSON(http.StatusBadRequest, "token is malformed")
             } else if ve.Errors&(jwt.ValidationErrorExpired|jwt.ValidationErrorNotValidYet) != 0 {
                 return c.JSON(http.StatusUnauthorized, "token is expired or not valid yet")
             } else {
                 return c.JSON(http.StatusBadRequest, "token is invalid")
             }
         }
         return nil
     },
 })

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《我的JWT自定义代码为什么不能成功执行echo?》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>