之前公司一直都是用java开发项目,一次偶然的机会接触到了go语言,所以一直想用go做一个小网站玩玩,选择了iris和gorm作为基础框架。但是对于用户的登录验证这块,左思右想还是跟公司的模式来,使用jwt。因为老本行是java,所以java版的jwt不用多说,然而go的jwt让我头疼,没去看jwt官网文档(需要翻译,头大,暂时不想阅读)也没有什么中文资料,所以自己琢磨,有什么不对的地方敬请指教,也是对目前的内容做个笔记。
需要导入的包:
import (
"encoding/json"
"fmt"
"github.com/dgrijalva/jwt-go"
"time"
)
//自定义一个key
keyInfo := "ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890!@#$%^&*()"
//将部分用户信息保存到map并转换为json
info := map[string]interface{}{}
info["userName"] = "Shisan"
dataByte,_:= json.Marshal(info)
var dataStr = string(dataByte)
//使用Claim保存json
//这里是个例子,并包含了一个故意签发一个已过期的token
data := jwt.StandardClaims{Subject:dataStr,ExpiresAt:time.Now().Unix()-1000}
tokenInfo := jwt.NewWithClaims(jwt.SigningMethodHS256,data)
//生成token字符串
tokenStr,_ := tokenInfo.SignedString([]byte(keyInfo))
fmt.Println("myToken is: ",tokenStr)
//将toke

本文介绍了如何在Go语言中使用JWT生成token,并详细讲述了如何获取token中的信息。作者在开发过程中,选择了Iris和Gorm作为基础框架,面对Go的JWT实现,通过自我探索和实践,总结了相关知识点,包括所需导入的包和源码中关键参数的获取。这篇文章对于初学者来说具有一定的参考价值。
最低0.47元/天 解锁文章
2679

被折叠的 条评论
为什么被折叠?



