wechat.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "hongze/hongze_cygx/models"
  5. "hongze/hongze_cygx/services"
  6. "hongze/hongze_cygx/utils"
  7. "strconv"
  8. "github.com/medivhzhan/weapp/v2"
  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.Authorization = this.Token
  310. resp.PhoneNumber = wxMobile.PhoneNumber
  311. resp.PurePhoneNumber = wxMobile.PurePhoneNumber
  312. resp.CountryCode = wxMobile.CountryCode
  313. br.Msg = "获取成功!"
  314. br.Ret = 200
  315. br.Success = true
  316. br.Data = resp
  317. }
  318. // @Title 获取短信验证码
  319. // @Description 获取短信验证码接口
  320. // @Param Mobile query string true "手机号码"
  321. // @Param AreaNum query string true "地区编码"
  322. // @Success Ret=200 获取成功
  323. // @router /getSmsCode [get]
  324. func (this *WechatController) GetSmsCode() {
  325. br := new(models.BaseResponse).Init()
  326. defer func() {
  327. this.Data["json"] = br
  328. this.ServeJSON()
  329. }()
  330. mobile := this.GetString("Mobile")
  331. if mobile == "" {
  332. br.Msg = "请输入手机号"
  333. return
  334. }
  335. areaNum := this.GetString("AreaNum")
  336. msgCode := utils.GetRandDigit(4)
  337. var result bool
  338. if areaNum == "86" || areaNum == "" || areaNum == "0" {
  339. result = services.SendSmsCode(mobile, msgCode)
  340. } else {
  341. result = services.SendSmsCodeGj(mobile, msgCode, areaNum)
  342. }
  343. //发送成功
  344. if result {
  345. item := new(models.MsgCode)
  346. item.OpenId = ""
  347. item.Code = msgCode
  348. item.Mobile = mobile
  349. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  350. item.Enabled = 1
  351. item.CreatedTime = time.Now()
  352. err := models.AddMsgCode(item)
  353. if err != nil {
  354. br.Msg = "发送失败"
  355. br.ErrMsg = "发送失败,Err:" + err.Error()
  356. return
  357. }
  358. br.Msg = "发送成功"
  359. } else {
  360. br.Msg = "发送失败"
  361. }
  362. br.Ret = 200
  363. br.Success = true
  364. }
  365. // @Title 获取邮件验证码
  366. // @Description 获取邮件验证码接口
  367. // @Param Email query string true "邮箱"
  368. // @Success Ret=200 获取成功
  369. // @router /getEmailCode [get]
  370. func (this *WechatController) GetEmailCode() {
  371. br := new(models.BaseResponse).Init()
  372. defer func() {
  373. this.Data["json"] = br
  374. this.ServeJSON()
  375. }()
  376. email := this.GetString("Email")
  377. if email == "" {
  378. br.Msg = "请输入邮箱地址"
  379. return
  380. }
  381. if !utils.ValidateEmailFormatat(email) {
  382. br.Msg = "邮箱格式错误,请重新输入"
  383. return
  384. }
  385. msgCode := utils.GetRandDigit(4)
  386. content := "尊敬的用户:</br>您好,感谢您使用弘则研究,您正在进行邮箱验证,本次请求的验证码为:" + msgCode + "(为了保障您账号的安全性,请在15分钟内完成验证。)</br>弘则研究团队 </br>2019年05月11日"
  387. title := "弘则研究登陆验证"
  388. //发送邮件
  389. result, err := utils.SendEmailByHz(title, content, email)
  390. if err != nil {
  391. br.Msg = "发送失败"
  392. br.ErrMsg = "发送失败,Err:" + err.Error()
  393. return
  394. }
  395. if result {
  396. item := new(models.MsgCode)
  397. item.OpenId = ""
  398. item.Code = msgCode
  399. item.Mobile = email
  400. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  401. item.Enabled = 1
  402. item.CreatedTime = time.Now()
  403. err := models.AddMsgCode(item)
  404. if err != nil {
  405. br.Msg = "发送失败"
  406. br.ErrMsg = "发送失败,Err:" + err.Error()
  407. return
  408. }
  409. br.Msg = "发送成功"
  410. } else {
  411. br.Msg = "发送失败"
  412. }
  413. br.Ret = 200
  414. br.Success = true
  415. }