wechat.go 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hongze_api/models"
  6. "hongze/hongze_api/services"
  7. "hongze/hongze_api/utils"
  8. "strconv"
  9. "time"
  10. )
  11. type WechatController struct {
  12. BaseAuthController
  13. }
  14. type WechatCommonController struct {
  15. BaseCommonController
  16. }
  17. // @Title 微信登录接口
  18. // @Description 微信登录接口
  19. // @Param Code query string true "微信唯一编码code"
  20. // @Success 200 {object} models.WxLoginResp
  21. // @router /login [get]
  22. func (this *WechatCommonController) WechatLogin() {
  23. br := new(models.BaseResponse).Init()
  24. defer func() {
  25. this.Data["json"] = br
  26. this.ServeJSON()
  27. }()
  28. code := this.GetString("Code")
  29. fmt.Println("code:", code)
  30. item, err := services.WxGetUserOpenIdByCode(code)
  31. if err != nil {
  32. br.Msg = "获取用户信息失败"
  33. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  34. return
  35. }
  36. if item.Errcode != 0 {
  37. br.Msg = "获取用户信息失败"
  38. br.ErrMsg = "获取access_token 失败 errcode:" + strconv.Itoa(item.Errcode) + " ;errmsg:" + item.Errmsg
  39. return
  40. }
  41. openId := item.Openid
  42. accessToken, err := services.WxGetAccessToken()
  43. if err != nil {
  44. br.Msg = "获取用户信息失败"
  45. br.ErrMsg = "获取access_token失败,err:" + err.Error()
  46. return
  47. }
  48. //获取用户信息
  49. wxUserInfo, err := services.WxGetUserInfo(openId, accessToken)
  50. if err != nil {
  51. br.Msg = "获取用户信息失败"
  52. br.ErrMsg = "获取微信用户信息失败,Err:" + err.Error()
  53. return
  54. }
  55. if wxUserInfo.Errcode != 0 {
  56. userInfoJson, _ := json.Marshal(wxUserInfo)
  57. br.Msg = "登录失败"
  58. br.ErrMsg = "获取用户信息失败,err:" + string(userInfoJson)
  59. return
  60. }
  61. unionid := item.Unionid
  62. if unionid == "" {
  63. unionid = wxUserInfo.Unionid
  64. }
  65. firstLogin := 1
  66. userId := 0
  67. utils.FileLog.Info("openId:%s", openId)
  68. utils.FileLog.Info("unionid:%s", unionid)
  69. //获取成功
  70. if unionid != "" {
  71. wxUser, err := models.GetWxUserItemByUnionid(unionid)
  72. if err != nil && err.Error() != utils.ErrNoRow() {
  73. br.Msg = "获取用户信息失败"
  74. br.ErrMsg = "根据openid获取用户信息失败,Eerr:" + err.Error()
  75. return
  76. }
  77. if wxUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  78. user := new(models.WxUser)
  79. user.OpenId = openId
  80. user.CompanyId = 1
  81. user.CreatedTime = time.Now()
  82. user.UnionId = unionid
  83. user.Unionid = unionid
  84. user.NickName = wxUserInfo.Nickname
  85. user.Sex = wxUserInfo.Sex
  86. user.City = wxUserInfo.City
  87. user.Province = wxUserInfo.Province
  88. user.Country = wxUserInfo.Country
  89. user.Headimgurl = wxUserInfo.Headimgurl
  90. user.FirstLogin = 1
  91. user.Enabled = 1
  92. user.RegisterPlatform = 1
  93. user.RegisterTime = time.Now()
  94. _, err = models.AddWxUser(user)
  95. wxUser, err = models.GetWxUserItemByUnionid(unionid)
  96. if err != nil {
  97. br.Msg = "获取用户信息失败"
  98. br.ErrMsg = "unionid登录,获取微信用户信息失败,Err:" + err.Error()
  99. return
  100. }
  101. userId = wxUser.UserId
  102. } else {
  103. firstLogin = wxUser.FirstLogin
  104. userId = wxUser.UserId
  105. }
  106. } else {
  107. if openId != "" {
  108. wxUser, err := models.GetWxUserItemByOpenId(openId)
  109. if err != nil && err.Error() != utils.ErrNoRow() {
  110. br.Msg = "获取用户信息失败"
  111. br.ErrMsg = "获取微信用户信息失败,Err:" + err.Error()
  112. return
  113. }
  114. if wxUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  115. user := new(models.WxUser)
  116. user.OpenId = openId
  117. user.CompanyId = 1
  118. user.CreatedTime = time.Now()
  119. user.UnionId = unionid
  120. user.Unionid = unionid
  121. user.NickName = wxUserInfo.Nickname
  122. user.Sex = wxUserInfo.Sex
  123. user.City = wxUserInfo.City
  124. user.Province = wxUserInfo.Province
  125. user.Country = wxUserInfo.Country
  126. user.Headimgurl = wxUserInfo.Headimgurl
  127. user.FirstLogin = 1
  128. user.Enabled = 1
  129. user.RegisterPlatform = 1
  130. user.RegisterTime = time.Now()
  131. _, err = models.AddWxUser(user)
  132. wxUser, err = models.GetWxUserItemByOpenId(openId)
  133. if err != nil {
  134. br.Msg = "获取用户信息失败"
  135. br.ErrMsg = "unionid登录,获取微信用户信息失败,Err:" + err.Error()
  136. return
  137. }
  138. userId = wxUser.UserId
  139. } else {
  140. userId = wxUser.UserId
  141. }
  142. }
  143. }
  144. permission, err := services.CheckUserPermission(userId)
  145. if err != nil {
  146. utils.FileLog.Info("userId:%s,err:%s", strconv.Itoa(userId), err)
  147. }
  148. //if err != nil {
  149. // br.Msg = "登录失败"
  150. // br.ErrMsg = "登录失败,判断权限失败:" + err.Error()
  151. // return
  152. //}
  153. var token string
  154. tokenItem, err := models.GetTokenByUid(userId)
  155. if err != nil && err.Error() != utils.ErrNoRow() {
  156. br.Msg = "登录失败"
  157. br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  158. return
  159. }
  160. if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  161. timeUnix := time.Now().Unix()
  162. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  163. token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  164. //新增session
  165. {
  166. session := new(models.Session)
  167. session.OpenId = openId
  168. session.UserId = userId
  169. session.CreatedTime = time.Now()
  170. session.LastUpdatedTime = time.Now()
  171. session.ExpireTime = time.Now().AddDate(0, 1, 0)
  172. session.AccessToken = token
  173. err = models.AddSession(session)
  174. if err != nil {
  175. br.Msg = "登录失败"
  176. br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  177. return
  178. }
  179. }
  180. } else {
  181. token = tokenItem.AccessToken
  182. }
  183. if wxUserInfo != nil {
  184. go models.ModifyWxUserInfo(wxUserInfo.Nickname, wxUserInfo.Headimgurl, wxUserInfo.City, wxUserInfo.Province, wxUserInfo.Country, wxUserInfo.Sex, userId)
  185. }
  186. resp := new(models.WxLoginResp)
  187. resp.UserId = userId
  188. resp.Code = 0
  189. resp.FirstLogin = firstLogin
  190. resp.Authorization = token
  191. resp.UserPermission = permission
  192. br.Ret = 200
  193. br.Success = true
  194. br.Msg = "登录成功"
  195. br.Data = resp
  196. }
  197. // @Title 微信获取签名接口
  198. // @Description 微信获取签名接口
  199. // @Param Url query string true "url地址"
  200. // @Success 200 {object} models.WechatSign
  201. // @router /getWxSign [get]
  202. func (this *WechatController) GetWxSign() {
  203. br := new(models.BaseResponse).Init()
  204. defer func() {
  205. this.Data["json"] = br
  206. this.ServeJSON()
  207. }()
  208. getUrl := this.GetString("Url")
  209. fmt.Println("getUrl:", getUrl)
  210. accessToken, err := services.WxGetAccessToken()
  211. if err != nil {
  212. br.Msg = "获取用户信息失败"
  213. br.ErrMsg = "获取access_token失败,err:" + err.Error()
  214. return
  215. }
  216. ticket, err := services.GetWxTicket(accessToken)
  217. if err != nil {
  218. br.Msg = "获取Ticket失败,请联系客服"
  219. br.ErrMsg = "获取Ticket失败,Err" + err.Error()
  220. return
  221. }
  222. if ticket == "" {
  223. br.Msg = "获取Ticket失败,请联系客服"
  224. br.ErrMsg = "ticket为空" + ticket
  225. return
  226. }
  227. nonceStr := utils.GetRandStringNoSpecialChar(16)
  228. signature, nonceString, timestamp := services.GetWxSignature(ticket, getUrl, nonceStr)
  229. resp := new(models.WechatSign)
  230. resp.AppId = utils.WxAppId
  231. resp.NonceStr = nonceString
  232. resp.Timestamp = timestamp
  233. resp.Url = getUrl
  234. resp.Signature = signature
  235. br.Ret = 200
  236. br.Success = true
  237. br.Msg = "获取签名成功"
  238. br.Data = resp
  239. }