wechat.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  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. } else {
  73. firstLogin = wxUser.FirstLogin
  74. userId = wxUser.UserId
  75. models.ModifyWxUserSessionKey(wxInfo.SessionKey, userId)
  76. }
  77. var token string
  78. tokenItem, err := models.GetTokenByUid(userId)
  79. if err != nil && err.Error() != utils.ErrNoRow() {
  80. br.Msg = "登录失败"
  81. br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  82. return
  83. }
  84. if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  85. timeUnix := time.Now().Unix()
  86. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  87. token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  88. //新增session
  89. {
  90. session := new(models.CygxSession)
  91. session.OpenId = wxInfo.OpenID
  92. session.UnionId = wxInfo.UnionID
  93. session.UserId = userId
  94. session.CreatedTime = time.Now()
  95. session.LastUpdatedTime = time.Now()
  96. session.ExpireTime = time.Now().AddDate(0, 3, 0)
  97. session.AccessToken = token
  98. err = models.AddSession(session)
  99. if err != nil {
  100. br.Msg = "登录失败"
  101. br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  102. return
  103. }
  104. }
  105. } else {
  106. token = tokenItem.AccessToken
  107. }
  108. {
  109. newItem, _ := models.GetWxUserItemByUserId(userId)
  110. if newItem.Mobile == "" && newItem.Email == "" {
  111. firstLogin = 1
  112. }
  113. }
  114. //新增登录日志
  115. {
  116. loginLog := new(models.WxUserLog)
  117. loginLog.UserId = userId
  118. loginLog.OpenId = wxInfo.OpenID
  119. loginLog.UnionId = wxInfo.UnionID
  120. loginLog.CreateTime = time.Now()
  121. loginLog.Handle = "wechat_login_cygx"
  122. loginLog.Remark = token
  123. go models.AddWxUserLog(loginLog)
  124. }
  125. {
  126. codeLog := new(models.WxUserCode)
  127. codeLog.WxCode = code
  128. codeLog.UserId = userId
  129. codeLog.Code = 0
  130. codeLog.FirstLogin = firstLogin
  131. codeLog.Authorization = token
  132. codeLog.UserPermission = 1
  133. codeLog.CreateTime = time.Now()
  134. models.AddWxUserCode(codeLog)
  135. }
  136. resp := new(models.WxLoginResp)
  137. resp.UserId = userId
  138. resp.FirstLogin = firstLogin
  139. resp.Authorization = token
  140. br.Ret = 200
  141. br.Success = true
  142. br.Msg = "登录成功"
  143. br.Data = resp
  144. }
  145. // @Title 小程序获取用户信息
  146. // @Description 小程序获取用户信息接口(需要登录)
  147. // @Param request body models.WxGetUserInfoReq true "type json string"
  148. // @Success 200 {object} models.WxGetUserInfoResp
  149. // @router /getUserInfo [post]
  150. func (this *WechatController) GetUserInfo() {
  151. br := new(models.BaseResponse).Init()
  152. defer func() {
  153. this.Data["json"] = br
  154. this.ServeJSON()
  155. }()
  156. var req models.WxGetUserInfoReq
  157. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  158. if err != nil {
  159. br.Msg = "参数解析异常!"
  160. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  161. return
  162. }
  163. if req.RawData == "" || req.EncryptedData == "" || req.Signature == "" || req.Iv == "" {
  164. br.Msg = "参数错误"
  165. return
  166. }
  167. user := this.User
  168. if user == nil {
  169. br.Msg = "请登陆"
  170. br.Ret = 408
  171. return
  172. }
  173. sessionKey := user.SessionKey
  174. userInfo, err := weapp.DecryptUserInfo(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  175. if err != nil {
  176. br.Msg = "解析用户信息失败"
  177. br.ErrMsg = "解析用户信息失败,DecryptUserInfo Err:" + err.Error()
  178. return
  179. }
  180. userId := 0
  181. //修改用户微信信息
  182. oldUser, err := models.GetWxUserItemByUnionid(userInfo.UnionID)
  183. if err != nil && err.Error() != utils.ErrNoRow() {
  184. br.Msg = "获取用户信息失败"
  185. br.ErrMsg = "获取用户信息失败 Err:" + err.Error()
  186. return
  187. }
  188. if oldUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  189. err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, user.UserId)
  190. if err != nil && err.Error() != utils.ErrNoRow() {
  191. br.Msg = "获取用户信息失败"
  192. br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  193. return
  194. }
  195. userId = user.UserId
  196. } else {
  197. if user.UserId == oldUser.UserId {
  198. err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, user.UserId)
  199. if err != nil && err.Error() != utils.ErrNoRow() {
  200. br.Msg = "获取用户信息失败"
  201. br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  202. return
  203. }
  204. userId = user.UserId
  205. } else {
  206. userId = oldUser.UserId
  207. err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, oldUser.UserId)
  208. if err != nil && err.Error() != utils.ErrNoRow() {
  209. br.Msg = "获取用户信息失败"
  210. br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  211. return
  212. }
  213. err = models.DeleteWxUserByUserId(user.UserId)
  214. if err != nil {
  215. br.Msg = "删除用户信息失败"
  216. br.ErrMsg = "删除用户信息失败 Err:" + err.Error()
  217. return
  218. }
  219. }
  220. }
  221. var token string
  222. tokenItem, err := models.GetTokenByUid(userId)
  223. if err != nil && err.Error() != utils.ErrNoRow() {
  224. br.Msg = "登录失败"
  225. br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  226. return
  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(strconv.Itoa(userId)) + 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.NickName = userInfo.Nickname
  254. //resp.Gender = userInfo.Gender
  255. //resp.Province = userInfo.Province
  256. //resp.Language = userInfo.Language
  257. //resp.Country = userInfo.Country
  258. //resp.City = userInfo.City
  259. //resp.AvatarUrl = userInfo.Avatar
  260. //resp.Appid = userInfo.Watermark.AppID
  261. //resp.Timestamp = userInfo.Watermark.Timestamp
  262. resp.Authorization = token
  263. br.Msg = "获取成功!"
  264. br.Ret = 200
  265. br.Success = true
  266. }
  267. // @Title 小程序获取用户绑定手机号
  268. // @Description 小程序获取用户绑定手机号接口(需要登录)
  269. // @Param request body models.WxGetPhoneNumberReq true "type json string"
  270. // @Success 200 {object} models.WxGetPhoneNumberResp
  271. // @router /getPhoneNumber [post]
  272. func (this *WechatController) GetPhoneNumber() {
  273. br := new(models.BaseResponse).Init()
  274. defer func() {
  275. this.Data["json"] = br
  276. this.ServeJSON()
  277. }()
  278. var req models.WxGetPhoneNumberReq
  279. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  280. if err != nil {
  281. br.Msg = "参数解析异常!"
  282. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  283. return
  284. }
  285. if req.EncryptedData == "" || req.Iv == "" {
  286. br.Msg = "参数错误"
  287. return
  288. }
  289. user := this.User
  290. if user == nil {
  291. br.Msg = "请登陆"
  292. br.Ret = 408
  293. return
  294. }
  295. sessionKey := user.SessionKey
  296. wxMobile, err := weapp.DecryptMobile(sessionKey, req.EncryptedData, req.Iv)
  297. if err != nil {
  298. br.Msg = "解析用户手机号信息失败"
  299. br.ErrMsg = "解析用户手机号信息失败,Err:" + err.Error()
  300. return
  301. }
  302. err = models.ModifyUsersMobile(user.UserId, wxMobile.PurePhoneNumber)
  303. if err != nil {
  304. br.Msg = "获取失败"
  305. br.ErrMsg = "获取失败,Err:" + err.Error()
  306. return
  307. }
  308. resp := new(models.WxGetPhoneNumberResp)
  309. resp.PhoneNumber = wxMobile.PhoneNumber
  310. resp.PurePhoneNumber = wxMobile.PurePhoneNumber
  311. resp.CountryCode = wxMobile.CountryCode
  312. br.Msg = "获取成功!"
  313. br.Ret = 200
  314. br.Success = true
  315. br.Data = resp
  316. }
  317. // @Title 获取短信验证码
  318. // @Description 获取短信验证码接口
  319. // @Param Mobile query string true "手机号码"
  320. // @Param AreaNum query string true "地区编码"
  321. // @Success Ret=200 获取成功
  322. // @router /getSmsCode [get]
  323. func (this *WechatController) GetSmsCode() {
  324. br := new(models.BaseResponse).Init()
  325. defer func() {
  326. this.Data["json"] = br
  327. this.ServeJSON()
  328. }()
  329. mobile := this.GetString("Mobile")
  330. if mobile == "" {
  331. br.Msg = "请输入手机号"
  332. return
  333. }
  334. areaNum := this.GetString("AreaNum")
  335. msgCode := utils.GetRandDigit(4)
  336. var result bool
  337. if areaNum == "86" || areaNum == "" || areaNum == "0" {
  338. result = services.SendSmsCode(mobile, msgCode)
  339. } else {
  340. result = services.SendSmsCodeGj(mobile, msgCode, areaNum)
  341. }
  342. //发送成功
  343. if result {
  344. item := new(models.MsgCode)
  345. item.OpenId = ""
  346. item.Code = msgCode
  347. item.Mobile = mobile
  348. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  349. item.Enabled = 1
  350. item.CreatedTime = time.Now()
  351. err := models.AddMsgCode(item)
  352. if err != nil {
  353. br.Msg = "发送失败"
  354. br.ErrMsg = "发送失败,Err:" + err.Error()
  355. return
  356. }
  357. br.Msg = "发送成功"
  358. } else {
  359. br.Msg = "发送失败"
  360. }
  361. br.Ret = 200
  362. br.Success = true
  363. }
  364. // @Title 获取邮件验证码
  365. // @Description 获取邮件验证码接口
  366. // @Param Email query string true "邮箱"
  367. // @Success Ret=200 获取成功
  368. // @router /getEmailCode [get]
  369. func (this *WechatController) GetEmailCode() {
  370. br := new(models.BaseResponse).Init()
  371. defer func() {
  372. this.Data["json"] = br
  373. this.ServeJSON()
  374. }()
  375. email := this.GetString("Email")
  376. if email == "" {
  377. br.Msg = "请输入邮箱地址"
  378. return
  379. }
  380. if !utils.ValidateEmailFormatat(email) {
  381. br.Msg = "邮箱格式错误,请重新输入"
  382. return
  383. }
  384. msgCode := utils.GetRandDigit(4)
  385. content := "尊敬的用户:</br>您好,感谢您使用弘则研究,您正在进行邮箱验证,本次请求的验证码为:" + msgCode + "(为了保障您账号的安全性,请在15分钟内完成验证。)</br>弘则研究团队 </br>2019年05月11日"
  386. title := "弘则研究登陆验证"
  387. //发送邮件
  388. result, err := utils.SendEmailByHz(title, content, email)
  389. if err != nil {
  390. br.Msg = "发送失败"
  391. br.ErrMsg = "发送失败,Err:" + err.Error()
  392. return
  393. }
  394. if result {
  395. item := new(models.MsgCode)
  396. item.OpenId = ""
  397. item.Code = msgCode
  398. item.Mobile = email
  399. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  400. item.Enabled = 1
  401. item.CreatedTime = time.Now()
  402. err := models.AddMsgCode(item)
  403. if err != nil {
  404. br.Msg = "发送失败"
  405. br.ErrMsg = "发送失败,Err:" + err.Error()
  406. return
  407. }
  408. br.Msg = "发送成功"
  409. } else {
  410. br.Msg = "发送失败"
  411. }
  412. br.Ret = 200
  413. br.Success = true
  414. }
  415. //
  416. //func init() {
  417. // fmt.Println("start")
  418. // sessionKey:=`CBDTrqAe0z8uvC8gFd3lJw==`
  419. // rawData:=`{"nickName":"freedom","gender":0,"language":"zh_CN","city":"","province":"","country":"","avatarUrl":"https://thirdwx.qlogo.cn/mmopen/vi_32/RsZCoxzBXkoeKlKjCkWPh8DR88rtD9PlOYLB7NaFsOmwQr2DOic3m9nh2azEnkZD2mzHZ7lf0oJ53Fh8ARQr9vA/132"}`
  420. // encryptedData:=`OuyYSyhocFgQSj68B4MVvJYJdLCJkSdSu0TuCU+nhcRB6Vzji8e7v/5nDJHsRLopEzUvi/fcUdJKoUtDap08kIxfFsvxKTRXn2OeaCams8Wf6dE4N27HaSpq91Ykfq7Zm33WJJi/PK4kn86t/2a1bBe2FQRrcLH40cLveglPn88MDC0N4cJ119Ab8V4OhTzIbeUNWtlD883GQL7saSsPBsiGhd4a8qoHVmQiZGVjjRJ0vH9X2K404MNKi0kmtcmTGTiecTptY/nf2ZOwohnVYFXVg6C2qFwpZw2ozRNRs7mBzBK818SBM8MHvS6gRuTwkc27/Yhn/7SH4Gq/DTDBoseEa/RENZJdYi1OqRSuS9q+qb5kfvf8GB8I6g+rA35oxvwdqhA3iyotzh91znHr1LMyqPg/ol59TL8T1GYh9ppcg5rrkgywmlF9N+YWaSqpruB9VUxoieKjZNtre1aq1GZAnxY7bwoe7a7u1Uu6vVpnP2kScJC2zK4IgmBExV4/`
  421. //
  422. // signature:=`a1a8a81ae75388bcbb66d92a6682ef4d16d4f634`
  423. // iv:=`ibri5rJxiWOT0Ar/6AfUXw==`
  424. // userInfo, err := weapp.DecryptUserInfo(sessionKey, rawData, encryptedData,signature, iv)
  425. // fmt.Println(userInfo)
  426. // fmt.Println(err)
  427. // fmt.Println("end")
  428. //}