之前公司一直都是用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,ExpiresA