tokenizer.go 976 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. package utl
  2. import (
  3. "fmt"
  4. "github.com/dgrijalva/jwt-go"
  5. "time"
  6. )
  7. type Tokenizer struct {
  8. key string // key
  9. lasts time.Duration // valid period
  10. }
  11. func NewToken(key string, lasts time.Duration) *Tokenizer {
  12. return &Tokenizer{
  13. key: key,
  14. lasts: lasts,
  15. }
  16. }
  17. func (self *Tokenizer) Gen(id uint64) (string, error) {
  18. clm := jwt.MapClaims{}
  19. clm["uid"] = id
  20. clm["exp"] = time.Now().Add(self.lasts)
  21. tok := jwt.NewWithClaims(jwt.SigningMethodHS512, clm)
  22. return tok.SignedString(self.key)
  23. }
  24. func (self *Tokenizer) Parse(tokenstr string) (uint64, error) {
  25. tok, err := jwt.Parse(tokenstr, func(token *jwt.Token) (interface{}, error) {
  26. if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {
  27. return nil, fmt.Errorf("unexpected signing method: %v", token.Header["alg"])
  28. }
  29. return self.key, nil
  30. })
  31. if err != nil {
  32. return 0, err
  33. }
  34. clm, ok := tok.Claims.(jwt.MapClaims)
  35. if !ok || !tok.Valid {
  36. return 0, err
  37. }
  38. return clm["uid"].(uint64), nil
  39. }