wechat.go 8.4 KB

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