wechat.go 5.7 KB

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