wechat.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486
  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.NickName = userInfo.Nickname
  287. //resp.Gender = userInfo.Gender
  288. //resp.Province = userInfo.Province
  289. //resp.Language = userInfo.Language
  290. //resp.Country = userInfo.Country
  291. //resp.City = userInfo.City
  292. //resp.AvatarUrl = userInfo.Avatar
  293. //resp.Appid = userInfo.Watermark.AppID
  294. //resp.Timestamp = userInfo.Watermark.Timestamp
  295. resp.Authorization = token
  296. br.Msg = "获取成功!"
  297. br.Ret = 200
  298. br.Success = true
  299. }
  300. // @Title 小程序获取用户绑定手机号
  301. // @Description 小程序获取用户绑定手机号接口(需要登录)
  302. // @Param request body models.WxGetPhoneNumberReq true "type json string"
  303. // @Success 200 {object} models.WxGetPhoneNumberResp
  304. // @router /getPhoneNumber [post]
  305. func (this *WechatController) GetPhoneNumber() {
  306. br := new(models.BaseResponse).Init()
  307. defer func() {
  308. this.Data["json"] = br
  309. this.ServeJSON()
  310. }()
  311. var req models.WxGetPhoneNumberReq
  312. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  313. if err != nil {
  314. br.Msg = "参数解析异常!"
  315. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  316. return
  317. }
  318. if req.EncryptedData == "" || req.Iv == "" {
  319. br.Msg = "参数错误"
  320. return
  321. }
  322. user := this.User
  323. if user == nil {
  324. br.Msg = "请登陆"
  325. br.Ret = 408
  326. return
  327. }
  328. sessionKey := user.SessionKey
  329. wxMobile, err := weapp.DecryptMobile(sessionKey, req.EncryptedData, req.Iv)
  330. if err != nil {
  331. br.Msg = "解析用户手机号信息失败"
  332. br.ErrMsg = "解析用户手机号信息失败,Err:" + err.Error()
  333. return
  334. }
  335. err = models.ModifyUsersMobile(user.UserId, wxMobile.PurePhoneNumber)
  336. if err != nil {
  337. br.Msg = "获取失败"
  338. br.ErrMsg = "获取失败,Err:" + err.Error()
  339. return
  340. }
  341. //更新用户记录信息
  342. {
  343. updateParams := make(map[string]interface{})
  344. updateParams["Mobile"]=wxMobile.PhoneNumber
  345. updateParams["BindAccount"]=wxMobile.PhoneNumber
  346. whereParam := map[string]interface{}{"user_id": user.UserId, "create_platform": 4}
  347. go models.UpdateByExpr(models.UserRecord{}, whereParam, updateParams)
  348. }
  349. resp := new(models.WxGetPhoneNumberResp)
  350. resp.PhoneNumber = wxMobile.PhoneNumber
  351. resp.PurePhoneNumber = wxMobile.PurePhoneNumber
  352. resp.CountryCode = wxMobile.CountryCode
  353. br.Msg = "获取成功!"
  354. br.Ret = 200
  355. br.Success = true
  356. br.Data = resp
  357. }
  358. // @Title 获取短信验证码
  359. // @Description 获取短信验证码接口
  360. // @Param Mobile query string true "手机号码"
  361. // @Param AreaNum query string true "地区编码"
  362. // @Success Ret=200 获取成功
  363. // @router /getSmsCode [get]
  364. func (this *WechatController) GetSmsCode() {
  365. br := new(models.BaseResponse).Init()
  366. defer func() {
  367. this.Data["json"] = br
  368. this.ServeJSON()
  369. }()
  370. mobile := this.GetString("Mobile")
  371. if mobile == "" {
  372. br.Msg = "请输入手机号"
  373. return
  374. }
  375. areaNum := this.GetString("AreaNum")
  376. msgCode := utils.GetRandDigit(4)
  377. var result bool
  378. if areaNum == "86" || areaNum == "" || areaNum == "0" {
  379. result = services.SendSmsCode(mobile, msgCode)
  380. } else {
  381. result = services.SendSmsCodeGj(mobile, msgCode, areaNum)
  382. }
  383. //发送成功
  384. if result {
  385. item := new(models.MsgCode)
  386. item.OpenId = ""
  387. item.Code = msgCode
  388. item.Mobile = mobile
  389. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  390. item.Enabled = 1
  391. item.CreatedTime = time.Now()
  392. err := models.AddMsgCode(item)
  393. if err != nil {
  394. br.Msg = "发送失败"
  395. br.ErrMsg = "发送失败,Err:" + err.Error()
  396. return
  397. }
  398. br.Msg = "发送成功"
  399. } else {
  400. br.Msg = "发送失败"
  401. }
  402. br.Ret = 200
  403. br.Success = true
  404. }
  405. // @Title 获取邮件验证码
  406. // @Description 获取邮件验证码接口
  407. // @Param Email query string true "邮箱"
  408. // @Success Ret=200 获取成功
  409. // @router /getEmailCode [get]
  410. func (this *WechatController) GetEmailCode() {
  411. br := new(models.BaseResponse).Init()
  412. defer func() {
  413. this.Data["json"] = br
  414. this.ServeJSON()
  415. }()
  416. email := this.GetString("Email")
  417. if email == "" {
  418. br.Msg = "请输入邮箱地址"
  419. return
  420. }
  421. if !utils.ValidateEmailFormatat(email) {
  422. br.Msg = "邮箱格式错误,请重新输入"
  423. return
  424. }
  425. msgCode := utils.GetRandDigit(4)
  426. content := "尊敬的用户:</br>您好,感谢您使用弘则研究,您正在进行邮箱验证,本次请求的验证码为:" + msgCode + "(为了保障您账号的安全性,请在15分钟内完成验证。)</br>弘则研究团队 </br>2019年05月11日"
  427. title := "弘则研究登陆验证"
  428. //发送邮件
  429. result, err := utils.SendEmailByHz(title, content, email)
  430. if err != nil {
  431. br.Msg = "发送失败"
  432. br.ErrMsg = "发送失败,Err:" + err.Error()
  433. return
  434. }
  435. if result {
  436. item := new(models.MsgCode)
  437. item.OpenId = ""
  438. item.Code = msgCode
  439. item.Mobile = email
  440. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  441. item.Enabled = 1
  442. item.CreatedTime = time.Now()
  443. err := models.AddMsgCode(item)
  444. if err != nil {
  445. br.Msg = "发送失败"
  446. br.ErrMsg = "发送失败,Err:" + err.Error()
  447. return
  448. }
  449. br.Msg = "发送成功"
  450. } else {
  451. br.Msg = "发送失败"
  452. }
  453. br.Ret = 200
  454. br.Success = true
  455. }
  456. //
  457. //func init() {
  458. // fmt.Println("start")
  459. // sessionKey:=`CBDTrqAe0z8uvC8gFd3lJw==`
  460. // rawData:=`{"nickName":"freedom","gender":0,"language":"zh_CN","city":"","province":"","country":"","avatarUrl":"https://thirdwx.qlogo.cn/mmopen/vi_32/RsZCoxzBXkoeKlKjCkWPh8DR88rtD9PlOYLB7NaFsOmwQr2DOic3m9nh2azEnkZD2mzHZ7lf0oJ53Fh8ARQr9vA/132"}`
  461. // encryptedData:=`OuyYSyhocFgQSj68B4MVvJYJdLCJkSdSu0TuCU+nhcRB6Vzji8e7v/5nDJHsRLopEzUvi/fcUdJKoUtDap08kIxfFsvxKTRXn2OeaCams8Wf6dE4N27HaSpq91Ykfq7Zm33WJJi/PK4kn86t/2a1bBe2FQRrcLH40cLveglPn88MDC0N4cJ119Ab8V4OhTzIbeUNWtlD883GQL7saSsPBsiGhd4a8qoHVmQiZGVjjRJ0vH9X2K404MNKi0kmtcmTGTiecTptY/nf2ZOwohnVYFXVg6C2qFwpZw2ozRNRs7mBzBK818SBM8MHvS6gRuTwkc27/Yhn/7SH4Gq/DTDBoseEa/RENZJdYi1OqRSuS9q+qb5kfvf8GB8I6g+rA35oxvwdqhA3iyotzh91znHr1LMyqPg/ol59TL8T1GYh9ppcg5rrkgywmlF9N+YWaSqpruB9VUxoieKjZNtre1aq1GZAnxY7bwoe7a7u1Uu6vVpnP2kScJC2zK4IgmBExV4/`
  462. //
  463. // signature:=`a1a8a81ae75388bcbb66d92a6682ef4d16d4f634`
  464. // iv:=`ibri5rJxiWOT0Ar/6AfUXw==`
  465. // userInfo, err := weapp.DecryptUserInfo(sessionKey, rawData, encryptedData,signature, iv)
  466. // fmt.Println(userInfo)
  467. // fmt.Println(err)
  468. // fmt.Println("end")
  469. //}