123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- package middleware
- import (
- "github.com/gin-gonic/gin"
- "hongze/hongze_yb/controller/response"
- "hongze/hongze_yb/models/tables/rddp/session"
- services "hongze/hongze_yb/services/user"
- "hongze/hongze_yb/utils"
- )
- func TokenNoLogin() gin.HandlerFunc {
- return func(c *gin.Context) {
- token := c.Request.Header.Get("Authorization")
- if token == "" {
- token = c.GetString("authorization")
- if token == "" {
- token = c.GetString("Authorization")
- }
- }
- if token == "" {
- response.TokenError(nil, "未登录或非法访问", "token为空", c)
- c.Abort()
- return
- }
- sessionInfo, err := session.GetTokenByToken(token)
- if err != nil {
- if err == utils.ErrNoRow {
- response.TokenError(nil, "信息已变更,请重新登陆!", "找不到session", c)
- c.Abort()
- return
- }
- response.TokenError(nil, "网络异常,请稍后重试!", err.Error(), c)
- c.Abort()
- return
- }
- if sessionInfo == nil {
- response.TokenError(nil, "网络异常,请稍后重试!", "session为空", c)
- c.Abort()
- return
- }
- var userInfo services.UserInfo
- //先判断pc端登录的情况
- tmpUserInfo, tmpErr := services.GetWxUserItemByUserId(int(sessionInfo.UserID), 3)
- userInfo = tmpUserInfo
- if tmpErr == utils.ErrNoRow && sessionInfo.OpenID != ""{
- tmpUserInfo, tmpErr = services.GetWxUserItemByOpenId(sessionInfo.OpenID)
- userInfo = tmpUserInfo
- err = tmpErr
- } else {
- response.TokenError(nil, "数据异常!", "openid为空", c)
- c.Abort()
- return
- }
- //如果查询异常,且异常信息不是:用户openid查询出来发现没有绑定用户
- if err != nil && err != services.ERR_USER_NOT_BIND {
- //没有找到记录
- if err == utils.ErrNoRow {
- response.TokenError(nil, "信息已变更,请重新登陆!", err.Error(), c)
- c.Abort()
- return
- }
- response.TokenError(nil, "网络异常,请稍后重试!", err.Error(), c)
- c.Abort()
- return
- }
- c.Set("userInfo", userInfo)
- c.Next()
- }
- }
|