token.go 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. package middleware
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "hongze/hongze_yb/controller/response"
  5. "hongze/hongze_yb/models/tables/rddp/session"
  6. services "hongze/hongze_yb/services/user"
  7. "hongze/hongze_yb/utils"
  8. )
  9. func Token() gin.HandlerFunc {
  10. return func(c *gin.Context) {
  11. token := c.Request.Header.Get("Authorization")
  12. if token == "" {
  13. token = c.GetString("authorization")
  14. if token == "" {
  15. token = c.GetString("Authorization")
  16. }
  17. }
  18. if token == "" {
  19. response.TokenError(nil, "未登录或非法访问", c)
  20. c.Abort()
  21. return
  22. }
  23. sessionInfo, err := session.GetTokenByToken(token)
  24. if err != nil {
  25. if err == utils.ErrNoRow {
  26. response.TokenError(nil, "信息已变更,请重新登陆!", c)
  27. c.Abort()
  28. return
  29. }
  30. response.TokenError(nil, "网络异常,请稍后重试!", c)
  31. c.Abort()
  32. return
  33. }
  34. if sessionInfo == nil {
  35. response.TokenError(nil, "网络异常,请稍后重试!", c)
  36. c.Abort()
  37. return
  38. }
  39. var userInfo services.UserInfo
  40. if sessionInfo.OpenID != "" {
  41. tmpUserInfo, tmpErr := services.GetWxUserItemByOpenId(sessionInfo.OpenID)
  42. userInfo = tmpUserInfo
  43. err = tmpErr
  44. } else {
  45. response.TokenError(nil, "数据异常!", c)
  46. c.Abort()
  47. return
  48. }
  49. if err != nil {
  50. //用户openid查询出来发现没有绑定用户
  51. if err == services.ERR_USER_NOT_BIND {
  52. response.TokenError(nil, "信息已变更,请重新登陆!", c)
  53. c.Abort()
  54. return
  55. }
  56. //没有找到记录
  57. if err == utils.ErrNoRow {
  58. response.TokenError(nil, "信息已变更,请重新登陆!", c)
  59. c.Abort()
  60. return
  61. }
  62. response.TokenError(nil, "网络异常,请稍后重试!", c)
  63. c.Abort()
  64. return
  65. }
  66. c.Set("userInfo", userInfo)
  67. c.Next()
  68. }
  69. }