主要針對jwt-go快速生成token。和如何取進行介紹,具體詳情還請查看git
package main import ( "flag" "fmt" "github.com/dgrijalva/jwt-go" "github.com/micro/go-micro/config" "time" ) type Config struct { Version string Hello struct { Name string } Etcd struct { Addrs []string UserName string Password string } } type User struct { Name string `json:"name"` Password string `json:"password"` Token struct { AccessToken string `json:"accessToken"` ExpiresAt int64 `json:"expiresAt"` Timestamp int64 `json:"timestamp"` } } func main() { // 主要解析config.json配置文件,生成token沒有用到 configFile := flag.String("f", "/go-gin-micro/config/config.json", "please use config.json") conf := new(Config) if err := config.LoadFile(*configFile); err != nil { return } if err := config.Scan(conf); err != nil { return } fmt.Println(conf) //md := map[string]string{ // "vector": "yang", //} user := &User{} claims := &jwt.StandardClaims{ ExpiresAt:time.Now().Add(30*time.Second).Unix(), // 過時時間,必須設置 Issuer:"wang", // 可沒必要設置,也能夠填充用戶名, } expired := time.Now().Add(148 * time.Hour).Unix() token := jwt.NewWithClaims(jwt.SigningMethodHS256,claims) //生成token accessToken, err := token.SignedString([]byte("vector.sign")) if err != nil { return } user.Token.ExpiresAt = expired user.Token.AccessToken = accessToken user.Token.Timestamp = time.Now().Unix() }
package main import ( "flag" "fmt" "github.com/dgrijalva/jwt-go" "time" ) func InitC(token string) { authorization := toekn token,err := jwt.Parse(authorization, func(token *jwt.Token) (i interface{}, e error) { return []byte("vector.sign"),nil }) if err != nil { // 第一種 //if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok { // fmt.Println("+++") // return //} //fmt.Println([]byte("vector.sign")) // 第二種 if err ,ok := err.(*jwt.ValidationError);ok { if err.Errors & jwt.ValidationErrorMalformed != 0 { return } if err.Errors & (jwt.ValidationErrorExpired | jwt.ValidationErrorNotValidYet) != 0 { fmt.Println(err) return } } return } finToken := token.Claims.(jwt.MapClaims) // 獲取token裏面的字段,如生成填入的username fmt.Println(finToken["iss"]) }