123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- package jwt
- import (
- "fmt"
- "kpt-tmr-group/config"
- "reflect"
- "time"
- "github.com/dgrijalva/jwt-go"
- )
- var jwtSecret = []byte(config.Options().JwtSecret)
- type Claims struct {
- Username string `json:"username"`
- Password string `json:"password"`
- jwt.StandardClaims
- }
- func GenerateToken(username, password string) (string, error) {
- nowTime := time.Now()
- expireTime := nowTime.Add(4 * time.Hour)
- claims := Claims{
- username,
- password,
- jwt.StandardClaims{
- ExpiresAt: expireTime.Unix(),
- Issuer: "https://github.com/kptyun/go-admin/",
- },
- }
- tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
- return tokenClaims.SignedString(jwtSecret)
- }
- func ParseToken(token string) (*Claims, error) {
- tokenClaims, err := jwt.ParseWithClaims(token, &Claims{}, func(token *jwt.Token) (interface{}, error) {
- return jwtSecret, nil
- })
- if tokenClaims != nil {
- if claims, ok := tokenClaims.Claims.(*Claims); ok && tokenClaims.Valid {
- return claims, nil
- }
- }
- return nil, err
- }
- func GetIdFromClaims(key string, claims jwt.Claims) string {
- v := reflect.ValueOf(claims)
- if v.Kind() == reflect.Map {
- for _, k := range v.MapKeys() {
- value := v.MapIndex(k)
- if fmt.Sprintf("%s", k.Interface()) == key {
- return fmt.Sprintf("%v", value.Interface())
- }
- }
- }
- return ""
- }
|