wechat.go 8.4 KB

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