美文网首页
gf-jwt 例子

gf-jwt 例子

作者: 王哈哈就很棒 | 来源:发表于2020-01-06 14:52 被阅读0次
package auth

import (
    jwt "github.com/gogf/gf-jwt"
    "github.com/gogf/gf/frame/g"
    "github.com/gogf/gf/net/ghttp"
    "github.com/gogf/gf/os/glog"
    "github.com/gogf/gf/util/gvalid"
    "net/http"
    "time"
)

var (
    // 底层JWT中间件。
    GfJWTMiddleware *jwt.GfJWTMiddleware
    // 自定义登录参数验证规则。
    ValidationRules = g.Map {
        "username": "required",
        "password": "required",
    }
)

// 初始化函数,
// 重写此函数以自定义您自己的JWT设置.
func init() {
    authMiddleware, err := jwt.New(&jwt.GfJWTMiddleware{
        Realm:           "test zone",
        Key:             []byte("secret key"),
        Timeout:         time.Minute * 5,
        MaxRefresh:      time.Minute * 5,
        IdentityKey:     "id",
        TokenLookup:     "header: Authorization, query: token, cookie: jwt",
        TokenHeadName:   "Bearer",
        TimeFunc:        time.Now,
        Authenticator:   Authenticator,
        LoginResponse:   LoginResponse,
        RefreshResponse: RefreshResponse,
        Unauthorized:    Unauthorized,
        IdentityHandler: IdentityHandler,
        PayloadFunc:     PayloadFunc,
    })
    if err != nil {
        glog.Fatal("JWT Error:" + err.Error())
    }
    GfJWTMiddleware = authMiddleware
}

//PayloadFunc是在登录期间调用的回调函数。
//使用此函数可以向webtoken添加其他负载数据。
//然后通过c.Get(“JWT_PAYLOAD”)在请求期间提供数据。
//请注意,有效负载未加密。
//jwt.io中提到的属性不能用作映射的键。
//可选,默认情况下不设置其他数据。
func PayloadFunc(data interface{}) jwt.MapClaims {
    claims := jwt.MapClaims{}
    params := data.(map[string]interface{})
    if len(params) > 0 {
        for k, v := range params {
            claims[k] = v
        }
    }
    return claims
}

// IdentityHandler设置JWT的标识。
func IdentityHandler(r *ghttp.Request) interface{} {
    claims := jwt.ExtractClaims(r)
    return claims["id"]
}

// Unauthorized用于定义自定义的Unauthorized回调函数。
func Unauthorized(r *ghttp.Request, code int, message string) {
    r.Response.WriteJson(g.Map{
        "code": code,
        "msg":  message,
    })
    r.ExitAll()
}

// LoginResponse用于定义自定义的登录成功回调函数。
func LoginResponse(r *ghttp.Request, code int, token string, expire time.Time) {
    r.Response.WriteJson(g.Map{
        "code":   http.StatusOK,
        "token":  token,
        "expire": expire.Format(time.RFC3339),
    })
    r.ExitAll()
}

// RefreshResponse用于获取新令牌,无论当前令牌是否过期.
func RefreshResponse(r *ghttp.Request, code int, token string, expire time.Time) {
    r.Response.WriteJson(g.Map{
        "code":   http.StatusOK,
        "token":  token,
        "expire": expire.Format(time.RFC3339),
    })
    r.ExitAll()
}

//身份验证器用于验证登录参数。
//它必须返回用户数据作为用户标识符,它将存储在声明数组中。
//检查错误(e)以确定适当的错误消息。
func Authenticator(r *ghttp.Request) (interface{}, error) {
    data := r.GetMap()
    if e := gvalid.CheckMap(data, ValidationRules); e != nil {
        return "", jwt.ErrFailedAuthentication
    }
    if data["username"] == "admin" && data["password"] == "admin" {
        return g.Map {
            "username": data["username"],
            "id":       data["username"],
        }, nil
    }
    return nil, jwt.ErrFailedAuthentication
}

相关文章

  • gf-jwt 例子

  • gf框架gf-jwt使用

    说明 插件地址 https://github.com/gogf/gf-jwtgf-jwt是gf框架的jwt 中间件...

  • 例子

    # 开学了 - 一天 -二天 - 三天

  • 例子

    例子1 例子2 例子3 例子4 例子5 例子6 超链接 黑体 下面是代码块 下面是引用 引用

  • 例子

    莫言在《母亲》一文里写到了两处他在小时候不能理解,但影响深远的事情。第一处是: 愁容满面的母亲,在辛苦地劳作时,嘴...

  • 例子

    要求1,三个inputview同时有值的时候按钮可点击. 要求2,网络请求完成之后,才能再次点击. 传统实现,在t...

  • 例子

    红绿灯真的那么有必要吗? 书里提到,荷兰的一个交通规划师莫德尔曼观察到,当一个城市停电导致红绿灯失...

  • 例子

    忽然想找个例子,既贴近生活,又能讲出深刻道理。 唱首歌就来了灵感。 生活就像我的歌声, 时而不靠谱 ,时而不着调。

  • 例子

    举两个例子: 一、肺部的硬化。就是肺泡组织因为炎症不能被及时治愈,造成溃疡,疤痕累累,肺泡逐渐被纤维性物质取代,产...

  • 例子

    很多查询都可以用经典的学生-课程-成绩案例来表示,下面是一些我在笔试或面试中遇到的经典题型。这些题目没有涉及到索引...

网友评论

      本文标题:gf-jwt 例子

      本文链接:https://www.haomeiwen.com/subject/bvrkactx.html