[Go] go语言使用dgrijalva/jwt-go 实现加解密jwt
2023-02-18 15:37:35 时间
当开发登录验证系统的时候
现在基本都是使用的jwt来实现的权限校验
这时候就涉及到了jwt的加密和解密
可以参考下面的使用方法
tools/jwt.go
package tools import ( "github.com/dgrijalva/jwt-go" "time" ) const SECRET = "taoshihan" type UserClaims struct { Id uint `json:"id"` Pid uint `json:"pid"` Username string `json:"username"` RoleId uint `json:"role_id"` CreateTime time.Time `json:"create_time"` jwt.StandardClaims } func MakeCliamsToken(obj UserClaims) (string, error) { token := jwt.NewWithClaims(jwt.SigningMethodHS256, obj) tokenString, err := token.SignedString([]byte(SECRET)) return tokenString, err } func ParseCliamsToken(token string) (*UserClaims, error) { tokenClaims, err := jwt.ParseWithClaims(token, &UserClaims{}, func(token *jwt.Token) (interface{}, error) { return []byte(SECRET), nil }) if tokenClaims != nil { if claims, ok := tokenClaims.Claims.(*UserClaims); ok && tokenClaims.Valid { return claims, nil } } return nil, err }
测试
tools/jwt_test.go
package tools import ( "github.com/dgrijalva/jwt-go" "testing" "time" ) func TestJwt(t *testing.T) { tokenCliams := UserClaims{ Id: 1, Username: "kefu2", RoleId: 2, Pid: 1, CreateTime: time.Now(), StandardClaims: jwt.StandardClaims{ ExpiresAt: time.Now().Unix() + 24*3600, }, } token, err := MakeCliamsToken(tokenCliams) t.Log(token, err) orgToken, err := ParseCliamsToken(token) t.Logf("%+v,%+v", orgToken, err) }
运行测试用例,可以看到加解密效果
可以测试下过期
相关文章
- 关于PHP缓冲控制在IE浏览器下的应用
- PHP的异常处理范例
- 最简单的配置Apache在Linux下自动启动的方法
- 在Linux下配置MySQL随系统自动启动
- 在Linux下编译MySQL时报错“No curses/termcap library found”解决方案
- 关于PHP的Session过期问题
- PHP笔试准备题目之基础题目
- 在Linux下为Apahce加载rewrite模块
- PHP的sprintf()函数学习研究笔记
- Linux阵营各版本的特点
- 让NuSphere PhpED的注释更规范
- 详解PHP中include和require的区别
- PHP 5.3.6 版本发布
- vsFTPd在Linux中的编译安装和配置方法(原创)
- Redhat/CentOS Linux常用配置
- Linux环境安装配置Nginx笔记
- PHP 5.4 alpha1 发布
- 高性能PHP框架 Yii 1.1.8 发布
- Eclipse 3.7(代号Indigo)正式版发布
- 用PHP实现验证码功能