wechat_pc.go 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  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. // @Title pc端微信登录接口
  12. // @Description pc端微信登录接口
  13. // @Param Code query string true "微信唯一编码code"
  14. // @Success 200 {object} models.WxLoginResp
  15. // @router /pc/login [get]
  16. func (this *WechatCommonController) PcWechatLogin() {
  17. br := new(models.BaseResponse).Init()
  18. defer func() {
  19. this.Data["json"] = br
  20. this.ServeJSON()
  21. }()
  22. code := this.GetString("Code")
  23. fmt.Println("code:", code)
  24. item, err := services.PcWxGetUserOpenIdByCode(code)
  25. if err != nil {
  26. br.Msg = "获取用户信息失败"
  27. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  28. return
  29. }
  30. if item.Errcode != 0 {
  31. br.Msg = "获取用户信息失败"
  32. br.ErrMsg = "获取access_token 失败 errcode:" + strconv.Itoa(item.Errcode) + " ;errmsg:" + item.Errmsg
  33. return
  34. }
  35. openId := item.Openid
  36. //accessToken, err := services.PcWxGetAccessToken()
  37. //utils.FileLog.Info("accessToken:%s", accessToken)
  38. //if err != nil {
  39. // br.Msg = "获取用户信息失败"
  40. // br.ErrMsg = "获取access_token失败,err:" + err.Error()
  41. // return
  42. //}
  43. utils.FileLog.Info("item.AccessToken):%s", item.AccessToken)
  44. //获取用户信息
  45. wxUserInfo, err := services.PcWxGetUserInfo(openId, item.AccessToken)
  46. if err != nil {
  47. br.Msg = "获取用户信息失败"
  48. br.ErrMsg = "获取微信用户信息失败,Err:" + err.Error()
  49. return
  50. }
  51. if wxUserInfo.Errcode != 0 {
  52. userInfoJson, _ := json.Marshal(wxUserInfo)
  53. br.Msg = "登录失败"
  54. br.ErrMsg = "获取用户信息失败,err:" + string(userInfoJson)
  55. return
  56. }
  57. var unionid string
  58. unionid = item.Unionid
  59. utils.FileLog.Info("item unionid:%s", unionid)
  60. if unionid == "" {
  61. unionid = wxUserInfo.Unionid
  62. }
  63. utils.FileLog.Info("openId:%s", openId)
  64. utils.FileLog.Info("unionid:%s", unionid)
  65. firstLogin := 1
  66. userId := 0
  67. //获取成功
  68. if unionid != "" {
  69. wxUser, err := models.GetWxUserItemByUnionid(unionid)
  70. if err != nil && err.Error() != utils.ErrNoRow() {
  71. br.Msg = "获取用户信息失败"
  72. br.ErrMsg = "根据openid获取用户信息失败,Eerr:" + err.Error()
  73. return
  74. }
  75. if wxUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  76. utils.FileLog.Info("用户不存在,注册")
  77. user := new(models.WxUser)
  78. user.OpenId = openId
  79. user.CompanyId = 1
  80. user.CreatedTime = time.Now()
  81. user.UnionId = unionid
  82. user.Unionid = unionid
  83. user.NickName = wxUserInfo.Nickname
  84. user.Sex = wxUserInfo.Sex
  85. user.City = wxUserInfo.City
  86. user.Province = wxUserInfo.Province
  87. user.Country = wxUserInfo.Country
  88. user.Headimgurl = wxUserInfo.Headimgurl
  89. user.FirstLogin = 1
  90. user.Enabled = 1
  91. user.RegisterTime = time.Now()
  92. user.RegisterPlatform = 2
  93. _, err = models.AddWxUser(user)
  94. wxUser, err = models.GetWxUserItemByUnionid(wxUserInfo.Unionid)
  95. if err != nil {
  96. br.Msg = "获取用户信息失败"
  97. br.ErrMsg = "获取微信用户信息失败,Err:" + err.Error()
  98. return
  99. }
  100. userId = wxUser.UserId
  101. } else {
  102. utils.FileLog.Info("用户已经存在")
  103. firstLogin = wxUser.FirstLogin
  104. userId = wxUser.UserId
  105. utils.FileLog.Info("用户已经存在,用户id:%d", userId)
  106. }
  107. } else {
  108. if openId != "" {
  109. wxUser, err := models.GetWxUserItemByOpenId(openId)
  110. if err != nil {
  111. br.Msg = "获取用户信息失败"
  112. br.ErrMsg = "获取微信用户信息失败,Err:" + err.Error()
  113. return
  114. }
  115. if wxUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  116. user := new(models.WxUser)
  117. user.OpenId = openId
  118. user.CompanyId = 1
  119. user.CreatedTime = time.Now()
  120. user.UnionId = unionid
  121. user.Unionid = unionid
  122. user.NickName = wxUserInfo.Nickname
  123. user.Sex = wxUserInfo.Sex
  124. user.City = wxUserInfo.City
  125. user.Province = wxUserInfo.Province
  126. user.Country = wxUserInfo.Country
  127. user.Headimgurl = wxUserInfo.Headimgurl
  128. user.FirstLogin = 1
  129. user.Enabled = 1
  130. user.RegisterPlatform = 1
  131. user.RegisterTime = time.Now()
  132. _, err = models.AddWxUser(user)
  133. wxUser, err = models.GetWxUserItemByOpenId(openId)
  134. if err != nil {
  135. br.Msg = "获取用户信息失败"
  136. br.ErrMsg = "unionid登录,获取微信用户信息失败,Err:" + err.Error()
  137. return
  138. }
  139. userId = wxUser.UserId
  140. } else {
  141. userId = wxUser.UserId
  142. }
  143. }
  144. }
  145. permission, err := services.CheckUserPermission(userId)
  146. if err != nil {
  147. br.Msg = "登录失败"
  148. br.ErrMsg = "登录失败,判断权限失败:" + err.Error()
  149. return
  150. }
  151. //更新用户微信信息
  152. if wxUserInfo != nil {
  153. models.ModifyWxUserInfo(wxUserInfo.Nickname, wxUserInfo.Headimgurl, wxUserInfo.City, wxUserInfo.Province, wxUserInfo.Country, wxUserInfo.Sex, userId)
  154. }
  155. newUser, _ := models.GetWxUserItemByUserId(userId)
  156. utils.FileLog.Info("获取用户信息:%d", userId)
  157. var token string
  158. tokenItem, err := models.GetTokenByUid(userId)
  159. if err != nil && err.Error() != utils.ErrNoRow() {
  160. br.Msg = "登录失败"
  161. br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  162. return
  163. }
  164. if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  165. timeUnix := time.Now().Unix()
  166. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  167. token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  168. //新增session
  169. {
  170. session := new(models.Session)
  171. session.UserId = userId
  172. session.CreatedTime = time.Now()
  173. session.LastUpdatedTime = time.Now()
  174. session.ExpireTime = time.Now().AddDate(0, 1, 0)
  175. session.AccessToken = token
  176. err = models.AddSession(session)
  177. if err != nil {
  178. br.Msg = "登录失败"
  179. br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  180. return
  181. }
  182. }
  183. } else {
  184. token = tokenItem.AccessToken
  185. }
  186. cp, err := models.GetCompanyProductsByUserId(userId)
  187. if err != nil {
  188. br.Msg = "登录失败"
  189. br.ErrMsg = "登录失败,获取客户信息失败:" + err.Error()
  190. return
  191. }
  192. var companyName, status, endDate, productName string
  193. for _, v := range cp {
  194. companyName = v.CompanyName
  195. if v.EndDate == "0000-00-00" {
  196. v.EndDate = ""
  197. }
  198. if status != "" {
  199. status = status + "/" + v.Status
  200. if v.EndDate != "" {
  201. endDate = endDate + "/" + v.Status + ":" + v.EndDate
  202. }
  203. productName = productName + "/" + v.ProductName
  204. } else {
  205. status = v.Status
  206. if v.EndDate != "" {
  207. endDate = v.Status + ":" + v.EndDate
  208. }
  209. productName = v.ProductName
  210. }
  211. }
  212. //新增登录日志
  213. {
  214. loginLog := new(models.WxUserLog)
  215. loginLog.UserId = userId
  216. loginLog.OpenId = openId
  217. loginLog.CreateTime = time.Now()
  218. loginLog.Handle="wechat_pc_login"
  219. loginLog.Remark=token
  220. go models.AddWxUserLog(loginLog)
  221. }
  222. resp := new(models.WxLoginResp)
  223. resp.UserId = userId
  224. resp.Code = 0
  225. resp.FirstLogin = firstLogin
  226. resp.Authorization = token
  227. resp.UserPermission = permission
  228. resp.Email = newUser.Email
  229. resp.Headimgurl = newUser.Headimgurl
  230. resp.Mobile = newUser.Mobile
  231. resp.CompanyName = companyName
  232. resp.EndDate = endDate
  233. resp.Status = status
  234. resp.ProductName = productName
  235. br.Ret = 200
  236. br.Success = true
  237. br.Msg = "登录成功"
  238. br.Data = resp
  239. }
  240. //func init() {
  241. // accessToken:=`40_6_YtSyR4Kg9MYbODrNVc1mpztpbZDPWb8aiNzgq96vfvSLGb59dTZk6dprQuhCdsPrqYRKFvaAAij0_NzR-rnMCb0Bxsngov9eLBuk4WQoI`
  242. // openId:=`oNUl652NjgjPz_C4M1ezCIro_s98`
  243. // item,err:=services.WxGetUserInfo(openId, accessToken)
  244. // fmt.Println(err)
  245. // fmt.Println(item)
  246. //}
  247. //func init() {
  248. // fmt.Println("start accessToken")
  249. // accessToken, err := services.PcWxGetAccessToken()
  250. // fmt.Println(err)
  251. // utils.FileLog.Info("accessToken:%s",accessToken)
  252. // fmt.Println("end accessToken")
  253. //}