wechat.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "github.com/medivhzhan/weapp/v2"
  5. "hongze/hongze_cygx/models"
  6. "hongze/hongze_cygx/services"
  7. "hongze/hongze_cygx/utils"
  8. "strconv"
  9. "time"
  10. )
  11. type WechatController struct {
  12. BaseAuthController
  13. }
  14. type WechatCommonController struct {
  15. BaseCommonController
  16. }
  17. // @Title 微信登录接口
  18. // @Description 微信登录接口
  19. // @Param Code query string true "微信唯一编码code"
  20. // @Success 200 {object} models.WxLoginResp
  21. // @router /login [get]
  22. func (this *WechatCommonController) WechatLogin() {
  23. br := new(models.BaseResponse).Init()
  24. defer func() {
  25. this.Data["json"] = br
  26. this.ServeJSON()
  27. }()
  28. code := this.GetString("Code")
  29. if code == "" {
  30. br.Msg = "参数错误"
  31. br.ErrMsg = "Code 为空"
  32. return
  33. }
  34. wxInfo, err := weapp.Login(utils.WxAppId, utils.WxAppSecret, code)
  35. if err != nil {
  36. br.Msg = "获取用户信息失败"
  37. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  38. return
  39. }
  40. if err = wxInfo.GetResponseError(); err != nil {
  41. br.Msg = "获取用户信息失败"
  42. br.ErrMsg = "获取用户信息失败,code:" + strconv.Itoa(wxInfo.ErrCode) + ",msg:" + wxInfo.ErrMSG
  43. return
  44. }
  45. firstLogin := 1
  46. userId := 0
  47. wxUser, err := models.GetWxUserItemByUnionid(wxInfo.UnionID)
  48. if err != nil && err.Error() != utils.ErrNoRow() {
  49. br.Msg = "获取用户信息失败"
  50. br.ErrMsg = "根据openid获取用户信息失败,Eerr:" + err.Error()
  51. return
  52. }
  53. if wxUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  54. user := new(models.WxUser)
  55. user.OpenId = wxInfo.OpenID
  56. user.CompanyId = 1
  57. user.CreatedTime = time.Now()
  58. user.UnionId = wxInfo.UnionID
  59. user.Unionid = wxInfo.UnionID
  60. user.FirstLogin = 1
  61. user.Enabled = 1
  62. user.RegisterPlatform = 1
  63. user.RegisterTime = time.Now()
  64. user.SessionKey = wxInfo.SessionKey
  65. newId, err := models.AddWxUser(user)
  66. if err != nil {
  67. br.Msg = "登录失败"
  68. br.ErrMsg = "登录失败,新增联系人失败,Eerr:" + err.Error()
  69. return
  70. }
  71. userId = int(newId)
  72. //新增用户记录
  73. {
  74. userRecord := new(models.UserRecord)
  75. userRecord.UserId = int(newId)
  76. userRecord.OpenId = user.OpenId
  77. userRecord.UnionId = user.UnionId
  78. userRecord.NickName = user.NickName
  79. userRecord.RealName = user.RealName
  80. userRecord.BindAccount = user.Mobile
  81. userRecord.Sex = user.Sex
  82. userRecord.Province = user.Province
  83. userRecord.City = user.City
  84. userRecord.Country = user.Country
  85. userRecord.Headimgurl = user.Headimgurl
  86. userRecord.CreateTime = time.Now()
  87. userRecord.CreatePlatform = 4
  88. userRecord.SessionKey = user.SessionKey
  89. go models.AddUserRecord(userRecord)
  90. }
  91. } else {
  92. firstLogin = wxUser.FirstLogin
  93. userId = wxUser.UserId
  94. models.ModifyWxUserSessionKey(wxInfo.SessionKey, userId)
  95. }
  96. var token string
  97. tokenItem, err := models.GetTokenByUid(userId)
  98. if err != nil && err.Error() != utils.ErrNoRow() {
  99. br.Msg = "登录失败"
  100. br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  101. return
  102. }
  103. if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  104. timeUnix := time.Now().Unix()
  105. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  106. token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  107. //新增session
  108. {
  109. session := new(models.CygxSession)
  110. session.OpenId = wxInfo.OpenID
  111. session.UnionId = wxInfo.UnionID
  112. session.UserId = userId
  113. session.CreatedTime = time.Now()
  114. session.LastUpdatedTime = time.Now()
  115. session.ExpireTime = time.Now().AddDate(0, 3, 0)
  116. session.AccessToken = token
  117. err = models.AddSession(session)
  118. if err != nil {
  119. br.Msg = "登录失败"
  120. br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  121. return
  122. }
  123. }
  124. } else {
  125. token = tokenItem.AccessToken
  126. }
  127. {
  128. newItem, _ := models.GetWxUserItemByUserId(userId)
  129. if newItem.Mobile == "" && newItem.Email == "" {
  130. firstLogin = 1
  131. }
  132. }
  133. //新增登录日志
  134. {
  135. loginLog := new(models.WxUserLog)
  136. loginLog.UserId = userId
  137. loginLog.OpenId = wxInfo.OpenID
  138. loginLog.UnionId = wxInfo.UnionID
  139. loginLog.CreateTime = time.Now()
  140. loginLog.Handle = "wechat_login_cygx"
  141. loginLog.Remark = token
  142. go models.AddWxUserLog(loginLog)
  143. }
  144. {
  145. codeLog := new(models.WxUserCode)
  146. codeLog.WxCode = code
  147. codeLog.UserId = userId
  148. codeLog.Code = 0
  149. codeLog.FirstLogin = firstLogin
  150. codeLog.Authorization = token
  151. codeLog.UserPermission = 1
  152. codeLog.CreateTime = time.Now()
  153. models.AddWxUserCode(codeLog)
  154. }
  155. resp := new(models.WxLoginResp)
  156. resp.UserId = userId
  157. resp.FirstLogin = firstLogin
  158. resp.Authorization = token
  159. br.Ret = 200
  160. br.Success = true
  161. br.Msg = "登录成功"
  162. br.Data = resp
  163. }
  164. // @Title 小程序获取用户信息
  165. // @Description 小程序获取用户信息接口(需要登录)
  166. // @Param request body models.WxGetUserInfoReq true "type json string"
  167. // @Success 200 {object} models.WxGetUserInfoResp
  168. // @router /getUserInfo [post]
  169. func (this *WechatController) GetUserInfo() {
  170. br := new(models.BaseResponse).Init()
  171. defer func() {
  172. this.Data["json"] = br
  173. this.ServeJSON()
  174. }()
  175. var req models.WxGetUserInfoReq
  176. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  177. if err != nil {
  178. br.Msg = "参数解析异常!"
  179. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  180. return
  181. }
  182. if req.RawData == "" || req.EncryptedData == "" || req.Signature == "" || req.Iv == "" {
  183. br.Msg = "参数错误"
  184. return
  185. }
  186. user := this.User
  187. if user == nil {
  188. br.Msg = "请登陆"
  189. br.Ret = 408
  190. return
  191. }
  192. sessionKey := user.SessionKey
  193. userInfo, err := weapp.DecryptUserInfo(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  194. if err != nil {
  195. br.Msg = "解析用户信息失败"
  196. br.ErrMsg = "解析用户信息失败,DecryptUserInfo Err:" + err.Error()
  197. return
  198. }
  199. userId := 0
  200. //修改用户微信信息
  201. oldUser, err := models.GetWxUserItemByUnionid(userInfo.UnionID)
  202. if err != nil && err.Error() != utils.ErrNoRow() {
  203. br.Msg = "获取用户信息失败"
  204. br.ErrMsg = "获取用户信息失败 Err:" + err.Error()
  205. return
  206. }
  207. if oldUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  208. err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, user.UserId)
  209. if err != nil && err.Error() != utils.ErrNoRow() {
  210. br.Msg = "获取用户信息失败"
  211. br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  212. return
  213. }
  214. userId = user.UserId
  215. } else {
  216. if user.UserId == oldUser.UserId {
  217. err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, user.UserId)
  218. if err != nil && err.Error() != utils.ErrNoRow() {
  219. br.Msg = "获取用户信息失败"
  220. br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  221. return
  222. }
  223. userId = user.UserId
  224. } else {
  225. userId = oldUser.UserId
  226. err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, oldUser.UserId)
  227. if err != nil && err.Error() != utils.ErrNoRow() {
  228. br.Msg = "获取用户信息失败"
  229. br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  230. return
  231. }
  232. err = models.DeleteWxUserByUserId(user.UserId)
  233. if err != nil {
  234. br.Msg = "删除用户信息失败"
  235. br.ErrMsg = "删除用户信息失败 Err:" + err.Error()
  236. return
  237. }
  238. }
  239. }
  240. //更新用户记录信息
  241. {
  242. updateParams := make(map[string]interface{})
  243. updateParams["NickName"]=userInfo.Nickname
  244. updateParams["Province"]=userInfo.Province
  245. updateParams["City"]=userInfo.City
  246. updateParams["Country"]=userInfo.Country
  247. updateParams["Headimgurl"]=userInfo.Avatar
  248. updateParams["Sex"]=userInfo.Gender
  249. updateParams["Headimgurl"]=userInfo.Avatar
  250. updateParams["UnionId"]=userInfo.UnionID
  251. whereParam := map[string]interface{}{"user_id": user.UserId, "create_platform": 4}
  252. go models.UpdateByExpr(models.UserRecord{}, whereParam, updateParams)
  253. }
  254. var token string
  255. tokenItem, err := models.GetTokenByUid(userId)
  256. if err != nil && err.Error() != utils.ErrNoRow() {
  257. br.Msg = "登录失败"
  258. br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  259. return
  260. }
  261. if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  262. timeUnix := time.Now().Unix()
  263. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  264. token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  265. //新增session
  266. {
  267. session := new(models.CygxSession)
  268. session.OpenId = userInfo.OpenID
  269. session.UnionId = userInfo.UnionID
  270. session.UserId = userId
  271. session.CreatedTime = time.Now()
  272. session.LastUpdatedTime = time.Now()
  273. session.ExpireTime = time.Now().AddDate(0, 3, 0)
  274. session.AccessToken = token
  275. err = models.AddSession(session)
  276. if err != nil {
  277. br.Msg = "登录失败"
  278. br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  279. return
  280. }
  281. }
  282. } else {
  283. token = tokenItem.AccessToken
  284. }
  285. resp := new(models.WxGetUserInfoResp)
  286. resp.Authorization = token
  287. br.Msg = "获取成功!"
  288. br.Ret = 200
  289. br.Success = true
  290. }
  291. // @Title 小程序获取用户绑定手机号
  292. // @Description 小程序获取用户绑定手机号接口(需要登录)
  293. // @Param request body models.WxGetPhoneNumberReq true "type json string"
  294. // @Success 200 {object} models.WxGetPhoneNumberResp
  295. // @router /getPhoneNumber [post]
  296. func (this *WechatController) GetPhoneNumber() {
  297. br := new(models.BaseResponse).Init()
  298. defer func() {
  299. this.Data["json"] = br
  300. this.ServeJSON()
  301. }()
  302. var req models.WxGetPhoneNumberReq
  303. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  304. if err != nil {
  305. br.Msg = "参数解析异常!"
  306. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  307. return
  308. }
  309. if req.EncryptedData == "" || req.Iv == "" {
  310. br.Msg = "参数错误"
  311. return
  312. }
  313. user := this.User
  314. if user == nil {
  315. br.Msg = "请登陆"
  316. br.Ret = 408
  317. return
  318. }
  319. sessionKey := user.SessionKey
  320. wxMobile, err := weapp.DecryptMobile(sessionKey, req.EncryptedData, req.Iv)
  321. if err != nil {
  322. br.Msg = "解析用户手机号信息失败"
  323. br.ErrMsg = "解析用户手机号信息失败,Err:" + err.Error()
  324. return
  325. }
  326. err = models.ModifyUsersMobile(user.UserId, wxMobile.PurePhoneNumber)
  327. if err != nil {
  328. br.Msg = "获取失败"
  329. br.ErrMsg = "获取失败,Err:" + err.Error()
  330. return
  331. }
  332. resp := new(models.WxGetPhoneNumberResp)
  333. resp.PhoneNumber = wxMobile.PhoneNumber
  334. resp.PurePhoneNumber = wxMobile.PurePhoneNumber
  335. resp.CountryCode = wxMobile.CountryCode
  336. br.Msg = "获取成功!"
  337. br.Ret = 200
  338. br.Success = true
  339. br.Data = resp
  340. }
  341. // @Title 获取短信验证码
  342. // @Description 获取短信验证码接口
  343. // @Param Mobile query string true "手机号码"
  344. // @Param AreaNum query string true "地区编码"
  345. // @Success Ret=200 获取成功
  346. // @router /getSmsCode [get]
  347. func (this *WechatController) GetSmsCode() {
  348. br := new(models.BaseResponse).Init()
  349. defer func() {
  350. this.Data["json"] = br
  351. this.ServeJSON()
  352. }()
  353. mobile := this.GetString("Mobile")
  354. if mobile == "" {
  355. br.Msg = "请输入手机号"
  356. return
  357. }
  358. areaNum := this.GetString("AreaNum")
  359. msgCode := utils.GetRandDigit(4)
  360. var result bool
  361. if areaNum == "86" || areaNum == "" || areaNum == "0" {
  362. result = services.SendSmsCode(mobile, msgCode)
  363. } else {
  364. result = services.SendSmsCodeGj(mobile, msgCode, areaNum)
  365. }
  366. //发送成功
  367. if result {
  368. item := new(models.MsgCode)
  369. item.OpenId = ""
  370. item.Code = msgCode
  371. item.Mobile = mobile
  372. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  373. item.Enabled = 1
  374. item.CreatedTime = time.Now()
  375. err := models.AddMsgCode(item)
  376. if err != nil {
  377. br.Msg = "发送失败"
  378. br.ErrMsg = "发送失败,Err:" + err.Error()
  379. return
  380. }
  381. br.Msg = "发送成功"
  382. } else {
  383. br.Msg = "发送失败"
  384. }
  385. br.Ret = 200
  386. br.Success = true
  387. }
  388. // @Title 获取邮件验证码
  389. // @Description 获取邮件验证码接口
  390. // @Param Email query string true "邮箱"
  391. // @Success Ret=200 获取成功
  392. // @router /getEmailCode [get]
  393. func (this *WechatController) GetEmailCode() {
  394. br := new(models.BaseResponse).Init()
  395. defer func() {
  396. this.Data["json"] = br
  397. this.ServeJSON()
  398. }()
  399. email := this.GetString("Email")
  400. if email == "" {
  401. br.Msg = "请输入邮箱地址"
  402. return
  403. }
  404. if !utils.ValidateEmailFormatat(email) {
  405. br.Msg = "邮箱格式错误,请重新输入"
  406. return
  407. }
  408. msgCode := utils.GetRandDigit(4)
  409. content := "尊敬的用户:</br>您好,感谢您使用弘则研究,您正在进行邮箱验证,本次请求的验证码为:" + msgCode + "(为了保障您账号的安全性,请在15分钟内完成验证。)</br>弘则研究团队 </br>2019年05月11日"
  410. title := "弘则研究登陆验证"
  411. //发送邮件
  412. result, err := utils.SendEmailByHz(title, content, email)
  413. if err != nil {
  414. br.Msg = "发送失败"
  415. br.ErrMsg = "发送失败,Err:" + err.Error()
  416. return
  417. }
  418. if result {
  419. item := new(models.MsgCode)
  420. item.OpenId = ""
  421. item.Code = msgCode
  422. item.Mobile = email
  423. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  424. item.Enabled = 1
  425. item.CreatedTime = time.Now()
  426. err := models.AddMsgCode(item)
  427. if err != nil {
  428. br.Msg = "发送失败"
  429. br.ErrMsg = "发送失败,Err:" + err.Error()
  430. return
  431. }
  432. br.Msg = "发送成功"
  433. } else {
  434. br.Msg = "发送失败"
  435. }
  436. br.Ret = 200
  437. br.Success = true
  438. }
  439. //
  440. //func init() {
  441. // fmt.Println("start")
  442. // sessionKey:=`CBDTrqAe0z8uvC8gFd3lJw==`
  443. // rawData:=`{"nickName":"freedom","gender":0,"language":"zh_CN","city":"","province":"","country":"","avatarUrl":"https://thirdwx.qlogo.cn/mmopen/vi_32/RsZCoxzBXkoeKlKjCkWPh8DR88rtD9PlOYLB7NaFsOmwQr2DOic3m9nh2azEnkZD2mzHZ7lf0oJ53Fh8ARQr9vA/132"}`
  444. // encryptedData:=`OuyYSyhocFgQSj68B4MVvJYJdLCJkSdSu0TuCU+nhcRB6Vzji8e7v/5nDJHsRLopEzUvi/fcUdJKoUtDap08kIxfFsvxKTRXn2OeaCams8Wf6dE4N27HaSpq91Ykfq7Zm33WJJi/PK4kn86t/2a1bBe2FQRrcLH40cLveglPn88MDC0N4cJ119Ab8V4OhTzIbeUNWtlD883GQL7saSsPBsiGhd4a8qoHVmQiZGVjjRJ0vH9X2K404MNKi0kmtcmTGTiecTptY/nf2ZOwohnVYFXVg6C2qFwpZw2ozRNRs7mBzBK818SBM8MHvS6gRuTwkc27/Yhn/7SH4Gq/DTDBoseEa/RENZJdYi1OqRSuS9q+qb5kfvf8GB8I6g+rA35oxvwdqhA3iyotzh91znHr1LMyqPg/ol59TL8T1GYh9ppcg5rrkgywmlF9N+YWaSqpruB9VUxoieKjZNtre1aq1GZAnxY7bwoe7a7u1Uu6vVpnP2kScJC2zK4IgmBExV4/`
  445. //
  446. // signature:=`a1a8a81ae75388bcbb66d92a6682ef4d16d4f634`
  447. // iv:=`ibri5rJxiWOT0Ar/6AfUXw==`
  448. // userInfo, err := weapp.DecryptUserInfo(sessionKey, rawData, encryptedData,signature, iv)
  449. // fmt.Println(userInfo)
  450. // fmt.Println(err)
  451. // fmt.Println("end")
  452. //}