wechat.go 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/medivhzhan/weapp/v2"
  6. "hongze/hongze_mobile_admin/models/response/wechat"
  7. "hongze/hongze_mobile_admin/services"
  8. "hongze/hongze_mobile_admin/utils"
  9. "strconv"
  10. )
  11. type WeChatCommon struct {
  12. BaseNotAuth
  13. }
  14. // @Title 微信登录接口
  15. // @Description 微信登录接口
  16. // @Param Code query string true "微信唯一编码code"
  17. // @Success 200 {object} wechat.WxLoginResp
  18. // @router /login [get]
  19. func (this *WeChatCommon) WeChatLogin() {
  20. code := this.GetString("Code")
  21. fmt.Println("code:", code)
  22. utils.FileLog.Info("WechatLogin code:%s", code)
  23. item, err := services.WxGetUserOpenIdByCode(code)
  24. if err != nil {
  25. this.FailWithMessage(fmt.Sprintf("%v", err), fmt.Sprintf("%v", err))
  26. return
  27. }
  28. if item.Errcode != 0 {
  29. this.FailWithMessage("获取用户信息失败", "获取access_token 失败 errcode:"+strconv.Itoa(item.Errcode)+" ;errmsg:"+item.Errmsg)
  30. }
  31. openId := item.Openid
  32. if openId == "" {
  33. this.FailWithMessage("获取用户信息失败", "获取openid失败,openid:"+item.Openid)
  34. }
  35. accessToken, err := services.WxGetAccessToken()
  36. if err != nil {
  37. this.FailWithMessage("获取用户信息失败", "获取access_token失败,err:"+err.Error())
  38. }
  39. //获取用户信息
  40. wxUserInfo, err := services.WxGetUserInfo(openId, accessToken)
  41. if err != nil {
  42. this.FailWithMessage("获取用户信息失败", "获取微信用户信息失败,Err:"+err.Error())
  43. }
  44. if wxUserInfo.Errcode != 0 {
  45. userInfoJson, _ := json.Marshal(wxUserInfo)
  46. this.FailWithMessage("登录失败", "获取用户信息失败,err:"+string(userInfoJson))
  47. return
  48. }
  49. token, adminWx, err := services.WxLogin(utils.WxPlatform, item, wxUserInfo)
  50. if err != nil {
  51. this.FailWithMessage("微信登录失败", "微信登录失败,err:"+err.Error())
  52. return
  53. }
  54. resp := wechat.WxLoginResp{
  55. AdminId: adminWx.AdminId,
  56. Code: 0,
  57. Authorization: token,
  58. Headimgurl: adminWx.Headimgurl,
  59. RealName: adminWx.RealName,
  60. }
  61. //登录日志
  62. {
  63. returnResult, err := json.Marshal(resp)
  64. if err != nil {
  65. utils.FileLog.Info(this.Ctx.Input.URI() + " Err:%s" + err.Error())
  66. }
  67. utils.FileLog.Info(this.Ctx.Input.URI()+" code: %s , return data: %s", code, string(returnResult))
  68. }
  69. this.OkDetailed(resp, "登录成功")
  70. }
  71. // @Title 微信登录接口
  72. // @Description 微信登录接口
  73. // @Param Code query string true "微信唯一编码code"
  74. // @Success 200 {object} wechat.WxLoginResp
  75. // @router /wxapp/login [get]
  76. func (this *WeChatCommon) WxAppLogin() {
  77. code := this.GetString("Code")
  78. if code == "" {
  79. this.FailWithMessage("参数错误", "Code 为空")
  80. return
  81. }
  82. wxInfo, err := weapp.Login(utils.WxAppId2, utils.WxAppSecret2, code)
  83. if err != nil {
  84. this.FailWithMessage("获取用户信息失败", "获取用户信息失败,Err:"+err.Error())
  85. return
  86. }
  87. if err = wxInfo.GetResponseError(); err != nil {
  88. this.FailWithMessage("获取用户信息失败", "获取用户信息失败,code:"+strconv.Itoa(wxInfo.ErrCode)+",msg:"+wxInfo.ErrMSG)
  89. return
  90. }
  91. item := &services.WxAccessToken{
  92. //AccessToken :wxInfo.
  93. //ExpiresIn :wxInfo.,
  94. //RefreshToken : wxInfo,
  95. Openid: wxInfo.OpenID,
  96. Unionid: wxInfo.UnionID,
  97. //Scope :wxInfo,
  98. Errcode: wxInfo.ErrCode,
  99. Errmsg: wxInfo.ErrMSG,
  100. }
  101. wxUserInfo := new(services.WxUserInfo)
  102. wxUserInfo.Unionid = wxInfo.UnionID
  103. wxUserInfo.Openid = wxInfo.OpenID
  104. wxUserInfo.Unionid = wxInfo.UnionID
  105. wxUserInfo.Errcode = wxInfo.ErrCode
  106. wxUserInfo.Errmsg = wxInfo.ErrMSG
  107. wxUserInfo.SessionKey = wxInfo.SessionKey
  108. fmt.Println("openId", wxInfo.OpenID)
  109. fmt.Println("unionId", wxInfo.UnionID)
  110. token, adminWx, err := services.WxLogin(utils.WxPlatform2, item, wxUserInfo)
  111. if err != nil {
  112. this.FailWithMessage("微信登录失败", "微信登录失败,err:"+err.Error())
  113. return
  114. }
  115. resp := wechat.WxLoginResp{
  116. AdminId: adminWx.AdminId,
  117. Code: 0,
  118. Authorization: token,
  119. Headimgurl: adminWx.Headimgurl,
  120. RealName: adminWx.RealName,
  121. }
  122. //登录日志
  123. {
  124. returnResult, err := json.Marshal(resp)
  125. if err != nil {
  126. utils.FileLog.Info(this.Ctx.Input.URI() + " Err:%s" + err.Error())
  127. }
  128. utils.FileLog.Info(this.Ctx.Input.URI()+" code: %s , return data: %s", code, string(returnResult))
  129. }
  130. this.OkDetailed(resp, "登录成功")
  131. }
  132. // @Title 小程序获取用户信息
  133. // @Description 小程序获取用户信息接口(需要登录)
  134. // @Param request body models.WxGetUserInfoReq true "type json string"
  135. // @Success 200 {object} models.WxGetUserInfoResp
  136. // @router /getUserInfo [post]
  137. //func (this *WechatController) GetUserInfo() {
  138. // br := new(models.BaseResponse).Init()
  139. // defer func() {
  140. // this.Data["json"] = br
  141. // this.ServeJSON()
  142. // }()
  143. // var req models.WxGetUserInfoReq
  144. // err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  145. // if err != nil {
  146. // br.Msg = "参数解析异常!"
  147. // br.ErrMsg = "参数解析失败,Err:" + err.Error()
  148. // return
  149. // }
  150. // if req.RawData == "" || req.EncryptedData == "" || req.Signature == "" || req.Iv == "" {
  151. // br.Msg = "参数错误"
  152. // return
  153. // }
  154. // user := this.User
  155. // if user == nil {
  156. // br.Msg = "请登陆"
  157. // br.Ret = 408
  158. // return
  159. // }
  160. // userId := user.UserId
  161. // sessionKey := user.SessionKey
  162. // fmt.Println("sessionKey:", sessionKey)
  163. // fmt.Println(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  164. // userInfo, err := weapp.DecryptUserInfo(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  165. // fmt.Println("weapp.DecryptUserInfo ", err)
  166. //
  167. // if err != nil {
  168. // br.Msg = "解析用户信息失败"
  169. // br.ErrMsg = "解析用户信息失败,DecryptUserInfo Err:" + err.Error()
  170. // return
  171. // }
  172. // //修改用户微信信息
  173. // err = models.ModifyUserRecordByDetail(userInfo.OpenID, userInfo.UnionID, userInfo.Nickname, userInfo.Avatar, userInfo.City, userInfo.Province, userInfo.Country, userInfo.Gender, userId)
  174. // if err != nil {
  175. // br.Msg = "授权失败"
  176. // br.ErrMsg = "授权失败,修改用户信息失败:" + err.Error()
  177. // return
  178. // }
  179. // var token string
  180. // tokenItem, err := models.GetTokenByOpenId(userInfo.OpenID)
  181. // if err != nil && err.Error() != utils.ErrNoRow() {
  182. // br.Msg = "授权失败"
  183. // br.ErrMsg = "授权失败,获取token失败:" + err.Error()
  184. // return
  185. // }
  186. //
  187. // if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  188. // timeUnix := time.Now().Unix()
  189. // timeUnixStr := strconv.FormatInt(timeUnix, 10)
  190. // token = utils.MD5(userInfo.OpenID) + utils.MD5(timeUnixStr)
  191. // //新增session
  192. // {
  193. // session := new(models.CygxSession)
  194. // session.OpenId = userInfo.OpenID
  195. // session.UnionId = userInfo.UnionID
  196. // session.UserId = userId
  197. // session.CreatedTime = time.Now()
  198. // session.LastUpdatedTime = time.Now()
  199. // session.ExpireTime = time.Now().AddDate(0, 3, 0)
  200. // session.AccessToken = token
  201. // err = models.AddSession(session)
  202. // if err != nil {
  203. // br.Msg = "授权失败"
  204. // br.ErrMsg = "授权失败,新增用户session信息失败:" + err.Error()
  205. // return
  206. // }
  207. // }
  208. // } else {
  209. // token = tokenItem.AccessToken
  210. // }
  211. // resp := new(models.WxGetUserInfoResp)
  212. // resp.Authorization = token
  213. // br.Msg = "获取成功!"
  214. // br.Ret = 200
  215. // br.Success = true
  216. //}