check_token_logic.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package token
  2. import (
  3. "context"
  4. "crypto/md5"
  5. "encoding/hex"
  6. "io"
  7. "strconv"
  8. "time"
  9. "wechat-api/ent"
  10. "wechat-api/ent/token"
  11. "wechat-api/internal/utils/dberrorhandler"
  12. "wechat-api/internal/svc"
  13. "wechat-api/internal/types"
  14. "github.com/zeromicro/go-zero/core/logx"
  15. )
  16. type CheckTokenLogic struct {
  17. logx.Logger
  18. ctx context.Context
  19. svcCtx *svc.ServiceContext
  20. }
  21. func NewCheckTokenLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CheckTokenLogic {
  22. return &CheckTokenLogic{
  23. Logger: logx.WithContext(ctx),
  24. ctx: ctx,
  25. svcCtx: svcCtx}
  26. }
  27. func (l *CheckTokenLogic) CheckToken(req *types.CheckTokenReq) (resp *types.CheckTokenResp, err error) {
  28. var (
  29. valid bool
  30. sign string
  31. )
  32. timestamp := time.Now().Unix()
  33. tokenItem, err := l.svcCtx.DB.Token.Query().Where(token.TokenEQ(*req.Token)).Limit(1).Only(l.ctx)
  34. if err != nil && !ent.IsNotFound(err) {
  35. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  36. }
  37. if tokenItem == nil { // 判断Token是否存在
  38. valid = false
  39. } else if tokenItem.ExpireAt.Unix() > timestamp { // 判断Token是否过期
  40. if tokenItem.MAC == "" { // 判断MAC是否存在,如果不存咋则说明是第一次激活该Token
  41. valid = true
  42. err = l.svcCtx.DB.Token.UpdateOneID(tokenItem.ID).SetNotNilMAC(req.Mac).Exec(l.ctx)
  43. if err != nil {
  44. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  45. }
  46. } else if tokenItem.MAC != *req.Mac { // 如果Mac地址不匹配说明该请求不合法
  47. valid = false
  48. } else { // 这是正常验证,返回OK
  49. valid = true
  50. }
  51. if valid {
  52. sign = generateSign(*req.Token, *req.Mac, strconv.Itoa(int(timestamp)))
  53. }
  54. }
  55. return &types.CheckTokenResp{
  56. Valid: &valid,
  57. Sign: &sign,
  58. Timestamp: &timestamp,
  59. }, nil
  60. }
  61. // 内部Md5方法
  62. func generateSign(token, mac, timestamp string) string {
  63. md5Token := easyMd5(token)
  64. md5Mac := easyMd5(mac)
  65. md5Ts := easyMd5(timestamp)
  66. return easyMd5(md5Token + md5Mac + md5Ts)
  67. }
  68. // 简易Md5用法
  69. func easyMd5(s string) string {
  70. hash := md5.New()
  71. _, _ = io.WriteString(hash, s)
  72. return hex.EncodeToString(hash.Sum(nil))
  73. }