wechat.go 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/medivhzhan/weapp/v2"
  6. "hongze/hongze_cygx/models"
  7. "hongze/hongze_cygx/services"
  8. "hongze/hongze_cygx/utils"
  9. "strconv"
  10. "time"
  11. )
  12. type WechatController struct {
  13. BaseAuthController
  14. }
  15. type WechatCommonController struct {
  16. BaseCommonController
  17. }
  18. //
  19. //// @Title 微信登录接口
  20. //// @Description 微信登录接口
  21. //// @Param Code query string true "微信唯一编码code"
  22. //// @Success 200 {object} models.WxLoginResp
  23. //// @router /login [get]
  24. //func (this *WechatCommonController) WechatLogin() {
  25. // br := new(models.BaseResponse).Init()
  26. // defer func() {
  27. // this.Data["json"] = br
  28. // this.ServeJSON()
  29. // }()
  30. // code := this.GetString("Code")
  31. // if code == "" {
  32. // br.Msg = "参数错误"
  33. // br.ErrMsg = "Code 为空"
  34. // return
  35. // }
  36. // wxInfo, err := weapp.Login(utils.WxAppId, utils.WxAppSecret, code)
  37. // if err != nil {
  38. // br.Msg = "获取用户信息失败"
  39. // br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  40. // return
  41. // }
  42. // if err = wxInfo.GetResponseError(); err != nil {
  43. // br.Msg = "获取用户信息失败"
  44. // br.ErrMsg = "获取用户信息失败,code:" + strconv.Itoa(wxInfo.ErrCode) + ",msg:" + wxInfo.ErrMSG
  45. // return
  46. // }
  47. // firstLogin := 1
  48. // userId := 0
  49. // wxUser, err := models.GetWxUserItemByUnionid(wxInfo.UnionID)
  50. // if err != nil && err.Error() != utils.ErrNoRow() {
  51. // br.Msg = "获取用户信息失败"
  52. // br.ErrMsg = "根据openid获取用户信息失败,Eerr:" + err.Error()
  53. // return
  54. // }
  55. // if wxUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  56. // user := new(models.WxUser)
  57. // user.OpenId = wxInfo.OpenID
  58. // user.CompanyId = 1
  59. // user.CreatedTime = time.Now()
  60. // user.UnionId = wxInfo.UnionID
  61. // user.Unionid = wxInfo.UnionID
  62. // user.FirstLogin = 1
  63. // user.Enabled = 1
  64. // user.RegisterPlatform = 1
  65. // user.RegisterTime = time.Now()
  66. // user.SessionKey = wxInfo.SessionKey
  67. // newId, err := models.AddWxUser(user)
  68. // if err != nil {
  69. // br.Msg = "登录失败"
  70. // br.ErrMsg = "登录失败,新增联系人失败,Eerr:" + err.Error()
  71. // return
  72. // }
  73. // userId = int(newId)
  74. // } else {
  75. // firstLogin = wxUser.FirstLogin
  76. // userId = wxUser.UserId
  77. // models.ModifyWxUserSessionKey(wxInfo.SessionKey, userId)
  78. // }
  79. //
  80. // var token string
  81. // tokenItem, err := models.GetTokenByUid(userId)
  82. // if err != nil && err.Error() != utils.ErrNoRow() {
  83. // br.Msg = "登录失败"
  84. // br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  85. // return
  86. // }
  87. //
  88. // if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  89. // timeUnix := time.Now().Unix()
  90. // timeUnixStr := strconv.FormatInt(timeUnix, 10)
  91. // token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  92. // //新增session
  93. // {
  94. // session := new(models.CygxSession)
  95. // session.OpenId = wxInfo.OpenID
  96. // session.UnionId = wxInfo.UnionID
  97. // session.UserId = userId
  98. // session.CreatedTime = time.Now()
  99. // session.LastUpdatedTime = time.Now()
  100. // session.ExpireTime = time.Now().AddDate(0, 3, 0)
  101. // session.AccessToken = token
  102. // err = models.AddSession(session)
  103. // if err != nil {
  104. // br.Msg = "登录失败"
  105. // br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  106. // return
  107. // }
  108. // }
  109. // } else {
  110. // token = tokenItem.AccessToken
  111. // }
  112. // {
  113. // newItem, _ := models.GetWxUserItemByUserId(userId)
  114. // if newItem.Mobile == "" && newItem.Email == "" {
  115. // firstLogin = 1
  116. // }
  117. // }
  118. //
  119. // //新增登录日志
  120. // {
  121. // loginLog := new(models.WxUserLog)
  122. // loginLog.UserId = userId
  123. // loginLog.OpenId = wxInfo.OpenID
  124. // loginLog.UnionId = wxInfo.UnionID
  125. // loginLog.CreateTime = time.Now()
  126. // loginLog.Handle = "wechat_login_cygx"
  127. // loginLog.Remark = token
  128. // go models.AddWxUserLog(loginLog)
  129. // }
  130. //
  131. // {
  132. // codeLog := new(models.WxUserCode)
  133. // codeLog.WxCode = code
  134. // codeLog.UserId = userId
  135. // codeLog.Code = 0
  136. // codeLog.FirstLogin = firstLogin
  137. // codeLog.Authorization = token
  138. // codeLog.UserPermission = 1
  139. // codeLog.CreateTime = time.Now()
  140. // models.AddWxUserCode(codeLog)
  141. // }
  142. //
  143. // resp := new(models.WxLoginResp)
  144. // resp.UserId = userId
  145. // resp.FirstLogin = firstLogin
  146. // resp.Authorization = token
  147. // br.Ret = 200
  148. // br.Success = true
  149. // br.Msg = "登录成功"
  150. // br.Data = resp
  151. //}
  152. // @Title 微信登录接口
  153. // @Description 微信登录接口
  154. // @Param Code query string true "微信唯一编码code"
  155. // @Success 200 {object} models.WxLoginResp
  156. // @router /login [get]
  157. func (this *WechatCommonController) WechatLogin() {
  158. br := new(models.BaseResponse).Init()
  159. defer func() {
  160. this.Data["json"] = br
  161. this.ServeJSON()
  162. }()
  163. code := this.GetString("Code")
  164. if code == "" {
  165. br.Msg = "参数错误"
  166. br.ErrMsg = "Code 为空"
  167. return
  168. }
  169. wxInfo, err := weapp.Login(utils.WxAppId, utils.WxAppSecret, code)
  170. if err != nil {
  171. br.Msg = "获取用户信息失败"
  172. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  173. return
  174. }
  175. if err = wxInfo.GetResponseError(); err != nil {
  176. br.Msg = "获取用户信息失败"
  177. br.ErrMsg = "获取用户信息失败,code:" + strconv.Itoa(wxInfo.ErrCode) + ",msg:" + wxInfo.ErrMSG
  178. return
  179. }
  180. //wxToken, err := services.WxGetToken()
  181. //if err != nil {
  182. // br.Msg = "获取用户信息失败"
  183. // br.ErrMsg = "获取access_token失败,err:" + err.Error()
  184. // return
  185. //}
  186. //if wxToken.AccessToken == "" {
  187. // br.Msg = "获取用户信息失败"
  188. // br.ErrMsg = "access_token 为空,"
  189. // return
  190. //}
  191. //getWxUserInfo, err := services.WxGetUserInfo(wxInfo.OpenID, wxToken.AccessToken)
  192. //if err != nil {
  193. // br.Msg = "获取用户信息失败"
  194. // br.ErrMsg = "获取微信用户信息失败,Err:" + err.Error()
  195. // return
  196. //}
  197. //if getWxUserInfo.Errcode != 0 {
  198. // userInfoJson, _ := json.Marshal(getWxUserInfo)
  199. // br.Msg = "登录失败"
  200. // br.ErrMsg = "获取用户信息失败,err:" + string(userInfoJson)
  201. // return
  202. //}
  203. wxUserInfo := new(services.WxUserInfo)
  204. wxUserInfo.Unionid = wxInfo.UnionID
  205. wxUserInfo.Openid = wxInfo.OpenID
  206. //wxUserInfo.Nickname = getWxUserInfo.Nickname
  207. //wxUserInfo.Headimgurl = getWxUserInfo.Headimgurl
  208. //wxUserInfo.City = getWxUserInfo.City
  209. //wxUserInfo.Province = getWxUserInfo.Province
  210. //wxUserInfo.Country = getWxUserInfo.Country
  211. //wxUserInfo.Sex = getWxUserInfo.Sex
  212. //wxUserInfo.SubscribeScene = getWxUserInfo.SubscribeScene
  213. wxUserInfo.Errcode = wxInfo.ErrCode
  214. wxUserInfo.Errmsg = wxInfo.ErrMSG
  215. wxUserInfo.SessionKey = wxInfo.SessionKey
  216. fmt.Println("openId", wxInfo.OpenID)
  217. fmt.Println("unionId", wxInfo.UnionID)
  218. token, userId, firstLogin, _, err := services.WxLogin(code, wxInfo.OpenID, wxInfo.UnionID, wxUserInfo)
  219. if err != nil && err.Error() != utils.ErrNoRow() {
  220. br.Msg = "微信登录失败"
  221. br.ErrMsg = "微信登录失败,err:" + err.Error()
  222. return
  223. }
  224. if token == "" {
  225. br.Msg = "微信登录失败"
  226. br.ErrMsg = "token:" + token + "" + code + " " + wxInfo.OpenID + " " + wxInfo.UnionID
  227. return
  228. }
  229. //新增登录日志
  230. {
  231. loginLog := new(models.WxUserLog)
  232. loginLog.UserId = userId
  233. loginLog.OpenId = wxInfo.OpenID
  234. loginLog.UnionId = wxInfo.UnionID
  235. loginLog.CreateTime = time.Now()
  236. loginLog.Handle = "wechat_login_cygx"
  237. loginLog.Remark = token
  238. go models.AddWxUserLog(loginLog)
  239. }
  240. {
  241. codeLog := new(models.WxUserCode)
  242. codeLog.WxCode = code
  243. codeLog.UserId = userId
  244. codeLog.Code = 0
  245. codeLog.FirstLogin = firstLogin
  246. codeLog.Authorization = token
  247. codeLog.UserPermission = 1
  248. codeLog.CreateTime = time.Now()
  249. models.AddWxUserCode(codeLog)
  250. }
  251. resp := new(models.WxLoginResp)
  252. resp.UserId = userId
  253. resp.FirstLogin = firstLogin
  254. resp.Authorization = token
  255. br.Ret = 200
  256. br.Success = true
  257. br.Msg = "登录成功"
  258. br.Data = resp
  259. }
  260. //
  261. //// @Title 小程序获取用户信息
  262. //// @Description 小程序获取用户信息接口(需要登录)
  263. //// @Param request body models.WxGetUserInfoReq true "type json string"
  264. //// @Success 200 {object} models.WxGetUserInfoResp
  265. //// @router /getUserInfo [post]
  266. //func (this *WechatController) GetUserInfo() {
  267. // br := new(models.BaseResponse).Init()
  268. // defer func() {
  269. // this.Data["json"] = br
  270. // this.ServeJSON()
  271. // }()
  272. // var req models.WxGetUserInfoReq
  273. // err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  274. // if err != nil {
  275. // br.Msg = "参数解析异常!"
  276. // br.ErrMsg = "参数解析失败,Err:" + err.Error()
  277. // return
  278. // }
  279. // if req.RawData == "" || req.EncryptedData == "" || req.Signature == "" || req.Iv == "" {
  280. // br.Msg = "参数错误"
  281. // return
  282. // }
  283. // user := this.User
  284. // if user == nil {
  285. // br.Msg = "请登陆"
  286. // br.Ret = 408
  287. // return
  288. // }
  289. // sessionKey := user.SessionKey
  290. // userInfo, err := weapp.DecryptUserInfo(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  291. // if err != nil {
  292. // br.Msg = "解析用户信息失败"
  293. // br.ErrMsg = "解析用户信息失败,DecryptUserInfo Err:" + err.Error()
  294. // return
  295. // }
  296. // userId := 0
  297. // //修改用户微信信息
  298. // oldUser, err := models.GetWxUserItemByUnionid(userInfo.UnionID)
  299. // if err != nil && err.Error() != utils.ErrNoRow() {
  300. // br.Msg = "获取用户信息失败"
  301. // br.ErrMsg = "获取用户信息失败 Err:" + err.Error()
  302. // return
  303. // }
  304. // if oldUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  305. // err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, user.UserId)
  306. // if err != nil && err.Error() != utils.ErrNoRow() {
  307. // br.Msg = "获取用户信息失败"
  308. // br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  309. // return
  310. // }
  311. // userId = user.UserId
  312. // } else {
  313. // if user.UserId == oldUser.UserId {
  314. // err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, user.UserId)
  315. // if err != nil && err.Error() != utils.ErrNoRow() {
  316. // br.Msg = "获取用户信息失败"
  317. // br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  318. // return
  319. // }
  320. // userId = user.UserId
  321. // } else {
  322. // userId = oldUser.UserId
  323. // err = models.ModifyWxUserInfo(userInfo.UnionID, userInfo.Nickname, userInfo.Province, userInfo.City, userInfo.Country, userInfo.Avatar, userInfo.Gender, oldUser.UserId)
  324. // if err != nil && err.Error() != utils.ErrNoRow() {
  325. // br.Msg = "获取用户信息失败"
  326. // br.ErrMsg = "修改用户信息失败 Err:" + err.Error()
  327. // return
  328. // }
  329. // err = models.DeleteWxUserByUserId(user.UserId)
  330. // if err != nil {
  331. // br.Msg = "删除用户信息失败"
  332. // br.ErrMsg = "删除用户信息失败 Err:" + err.Error()
  333. // return
  334. // }
  335. // }
  336. // }
  337. // var token string
  338. // tokenItem, err := models.GetTokenByUid(userId)
  339. // if err != nil && err.Error() != utils.ErrNoRow() {
  340. // br.Msg = "登录失败"
  341. // br.ErrMsg = "登录失败,获取token失败:" + err.Error()
  342. // return
  343. // }
  344. //
  345. // if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  346. // timeUnix := time.Now().Unix()
  347. // timeUnixStr := strconv.FormatInt(timeUnix, 10)
  348. // token = utils.MD5(strconv.Itoa(userId)) + utils.MD5(timeUnixStr)
  349. // //新增session
  350. // {
  351. // session := new(models.CygxSession)
  352. // session.OpenId = userInfo.OpenID
  353. // session.UnionId = userInfo.UnionID
  354. // session.UserId = userId
  355. // session.CreatedTime = time.Now()
  356. // session.LastUpdatedTime = time.Now()
  357. // session.ExpireTime = time.Now().AddDate(0, 3, 0)
  358. // session.AccessToken = token
  359. // err = models.AddSession(session)
  360. // if err != nil {
  361. // br.Msg = "登录失败"
  362. // br.ErrMsg = "登录失败,新增用户session信息失败:" + err.Error()
  363. // return
  364. // }
  365. // }
  366. // } else {
  367. // token = tokenItem.AccessToken
  368. // }
  369. // resp := new(models.WxGetUserInfoResp)
  370. // resp.Authorization = token
  371. // br.Msg = "获取成功!"
  372. // br.Ret = 200
  373. // br.Success = true
  374. //}
  375. // @Title 小程序获取用户信息
  376. // @Description 小程序获取用户信息接口(需要登录)
  377. // @Param request body models.WxGetUserInfoReq true "type json string"
  378. // @Success 200 {object} models.WxGetUserInfoResp
  379. // @router /getUserInfo [post]
  380. func (this *WechatController) GetUserInfo() {
  381. br := new(models.BaseResponse).Init()
  382. defer func() {
  383. this.Data["json"] = br
  384. this.ServeJSON()
  385. }()
  386. var req models.WxGetUserInfoReq
  387. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  388. if err != nil {
  389. br.Msg = "参数解析异常!"
  390. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  391. return
  392. }
  393. if req.RawData == "" || req.EncryptedData == "" || req.Signature == "" || req.Iv == "" {
  394. br.Msg = "参数错误"
  395. return
  396. }
  397. user := this.User
  398. if user == nil {
  399. br.Msg = "请登陆"
  400. br.Ret = 408
  401. return
  402. }
  403. userId := user.UserId
  404. sessionKey := user.SessionKey
  405. fmt.Println("sessionKey:", sessionKey)
  406. fmt.Println(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  407. userInfo, err := weapp.DecryptUserInfo(sessionKey, req.RawData, req.EncryptedData, req.Signature, req.Iv)
  408. fmt.Println("weapp.DecryptUserInfo ", err)
  409. if err != nil {
  410. br.Msg = "解析用户信息失败"
  411. br.ErrMsg = "解析用户信息失败,DecryptUserInfo Err:" + err.Error()
  412. return
  413. }
  414. //修改用户微信信息
  415. err = models.ModifyUserRecordByDetail(userInfo.OpenID, userInfo.UnionID, userInfo.Nickname, userInfo.Avatar, userInfo.City, userInfo.Province, userInfo.Country, userInfo.Gender, userId)
  416. if err != nil {
  417. br.Msg = "授权失败"
  418. br.ErrMsg = "授权失败,修改用户信息失败:" + err.Error()
  419. return
  420. }
  421. var token string
  422. tokenItem, err := models.GetTokenByOpenId(userInfo.OpenID)
  423. if err != nil && err.Error() != utils.ErrNoRow() {
  424. br.Msg = "授权失败"
  425. br.ErrMsg = "授权失败,获取token失败:" + err.Error()
  426. return
  427. }
  428. if tokenItem == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  429. timeUnix := time.Now().Unix()
  430. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  431. token = utils.MD5(userInfo.OpenID) + utils.MD5(timeUnixStr)
  432. //新增session
  433. {
  434. session := new(models.CygxSession)
  435. session.OpenId = userInfo.OpenID
  436. session.UnionId = userInfo.UnionID
  437. session.UserId = userId
  438. session.CreatedTime = time.Now()
  439. session.LastUpdatedTime = time.Now()
  440. session.ExpireTime = time.Now().AddDate(0, 3, 0)
  441. session.AccessToken = token
  442. err = models.AddSession(session)
  443. if err != nil {
  444. br.Msg = "授权失败"
  445. br.ErrMsg = "授权失败,新增用户session信息失败:" + err.Error()
  446. return
  447. }
  448. }
  449. } else {
  450. token = tokenItem.AccessToken
  451. }
  452. resp := new(models.WxGetUserInfoResp)
  453. resp.Authorization = token
  454. br.Msg = "获取成功!"
  455. br.Ret = 200
  456. br.Success = true
  457. }
  458. // @Title 小程序获取用户绑定手机号
  459. // @Description 小程序获取用户绑定手机号接口(需要登录)
  460. // @Param request body models.WxGetPhoneNumberReq true "type json string"
  461. // @Success 200 {object} models.WxGetPhoneNumberResp
  462. // @router /getPhoneNumber [post]
  463. func (this *WechatController) GetPhoneNumber() {
  464. br := new(models.BaseResponse).Init()
  465. defer func() {
  466. this.Data["json"] = br
  467. this.ServeJSON()
  468. }()
  469. var req models.WxGetPhoneNumberReq
  470. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  471. if err != nil {
  472. br.Msg = "参数解析异常!"
  473. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  474. return
  475. }
  476. if req.EncryptedData == "" || req.Iv == "" {
  477. br.Msg = "参数错误"
  478. return
  479. }
  480. user := this.User
  481. if user == nil {
  482. br.Msg = "请登陆"
  483. br.Ret = 408
  484. return
  485. }
  486. sessionKey := user.SessionKey
  487. wxMobile, err := weapp.DecryptMobile(sessionKey, req.EncryptedData, req.Iv)
  488. if err != nil {
  489. br.Msg = "解析用户手机号信息失败"
  490. br.ErrMsg = "解析用户手机号信息失败,Err:" + err.Error()
  491. return
  492. }
  493. err = models.ModifyUsersMobile(user.UserId, wxMobile.PurePhoneNumber)
  494. if err != nil {
  495. br.Msg = "获取失败"
  496. br.ErrMsg = "获取失败,Err:" + err.Error()
  497. return
  498. }
  499. resp := new(models.WxGetPhoneNumberResp)
  500. resp.PhoneNumber = wxMobile.PhoneNumber
  501. resp.PurePhoneNumber = wxMobile.PurePhoneNumber
  502. resp.CountryCode = wxMobile.CountryCode
  503. br.Msg = "获取成功!"
  504. br.Ret = 200
  505. br.Success = true
  506. br.Data = resp
  507. }
  508. // @Title 获取短信验证码
  509. // @Description 获取短信验证码接口
  510. // @Param Mobile query string true "手机号码"
  511. // @Param AreaNum query string true "地区编码"
  512. // @Success Ret=200 获取成功
  513. // @router /getSmsCode [get]
  514. func (this *WechatController) GetSmsCode() {
  515. br := new(models.BaseResponse).Init()
  516. defer func() {
  517. this.Data["json"] = br
  518. this.ServeJSON()
  519. }()
  520. mobile := this.GetString("Mobile")
  521. if mobile == "" {
  522. br.Msg = "请输入手机号"
  523. return
  524. }
  525. areaNum := this.GetString("AreaNum")
  526. msgCode := utils.GetRandDigit(4)
  527. var result bool
  528. if areaNum == "86" || areaNum == "" || areaNum == "0" {
  529. result = services.SendSmsCode(mobile, msgCode)
  530. } else {
  531. result = services.SendSmsCodeGj(mobile, msgCode, areaNum)
  532. }
  533. //发送成功
  534. if result {
  535. item := new(models.MsgCode)
  536. item.OpenId = ""
  537. item.Code = msgCode
  538. item.Mobile = mobile
  539. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  540. item.Enabled = 1
  541. item.CreatedTime = time.Now()
  542. err := models.AddMsgCode(item)
  543. if err != nil {
  544. br.Msg = "发送失败"
  545. br.ErrMsg = "发送失败,Err:" + err.Error()
  546. return
  547. }
  548. br.Msg = "发送成功"
  549. } else {
  550. br.Msg = "发送失败"
  551. }
  552. br.Ret = 200
  553. br.Success = true
  554. }
  555. // @Title 获取邮件验证码
  556. // @Description 获取邮件验证码接口
  557. // @Param Email query string true "邮箱"
  558. // @Success Ret=200 获取成功
  559. // @router /getEmailCode [get]
  560. func (this *WechatController) GetEmailCode() {
  561. br := new(models.BaseResponse).Init()
  562. defer func() {
  563. this.Data["json"] = br
  564. this.ServeJSON()
  565. }()
  566. email := this.GetString("Email")
  567. if email == "" {
  568. br.Msg = "请输入邮箱地址"
  569. return
  570. }
  571. if !utils.ValidateEmailFormatat(email) {
  572. br.Msg = "邮箱格式错误,请重新输入"
  573. return
  574. }
  575. msgCode := utils.GetRandDigit(4)
  576. content := "尊敬的用户:</br>您好,感谢您使用弘则研究,您正在进行邮箱验证,本次请求的验证码为:" + msgCode + "(为了保障您账号的安全性,请在15分钟内完成验证。)</br>弘则研究团队 </br>2019年05月11日"
  577. title := "弘则研究登陆验证"
  578. //发送邮件
  579. result, err := utils.SendEmailByHz(title, content, email)
  580. if err != nil {
  581. br.Msg = "发送失败"
  582. br.ErrMsg = "发送失败,Err:" + err.Error()
  583. return
  584. }
  585. if result {
  586. item := new(models.MsgCode)
  587. item.OpenId = ""
  588. item.Code = msgCode
  589. item.Mobile = email
  590. item.ExpiredIn = time.Now().Add(15 * time.Minute).Unix()
  591. item.Enabled = 1
  592. item.CreatedTime = time.Now()
  593. err := models.AddMsgCode(item)
  594. if err != nil {
  595. br.Msg = "发送失败"
  596. br.ErrMsg = "发送失败,Err:" + err.Error()
  597. return
  598. }
  599. br.Msg = "发送成功"
  600. } else {
  601. br.Msg = "发送失败"
  602. }
  603. br.Ret = 200
  604. br.Success = true
  605. }
  606. //
  607. //func init() {
  608. // fmt.Println("start")
  609. // sessionKey:=`CBDTrqAe0z8uvC8gFd3lJw==`
  610. // rawData:=`{"nickName":"freedom","gender":0,"language":"zh_CN","city":"","province":"","country":"","avatarUrl":"https://thirdwx.qlogo.cn/mmopen/vi_32/RsZCoxzBXkoeKlKjCkWPh8DR88rtD9PlOYLB7NaFsOmwQr2DOic3m9nh2azEnkZD2mzHZ7lf0oJ53Fh8ARQr9vA/132"}`
  611. // encryptedData:=`OuyYSyhocFgQSj68B4MVvJYJdLCJkSdSu0TuCU+nhcRB6Vzji8e7v/5nDJHsRLopEzUvi/fcUdJKoUtDap08kIxfFsvxKTRXn2OeaCams8Wf6dE4N27HaSpq91Ykfq7Zm33WJJi/PK4kn86t/2a1bBe2FQRrcLH40cLveglPn88MDC0N4cJ119Ab8V4OhTzIbeUNWtlD883GQL7saSsPBsiGhd4a8qoHVmQiZGVjjRJ0vH9X2K404MNKi0kmtcmTGTiecTptY/nf2ZOwohnVYFXVg6C2qFwpZw2ozRNRs7mBzBK818SBM8MHvS6gRuTwkc27/Yhn/7SH4Gq/DTDBoseEa/RENZJdYi1OqRSuS9q+qb5kfvf8GB8I6g+rA35oxvwdqhA3iyotzh91znHr1LMyqPg/ol59TL8T1GYh9ppcg5rrkgywmlF9N+YWaSqpruB9VUxoieKjZNtre1aq1GZAnxY7bwoe7a7u1Uu6vVpnP2kScJC2zK4IgmBExV4/`
  612. //
  613. // signature:=`a1a8a81ae75388bcbb66d92a6682ef4d16d4f634`
  614. // iv:=`ibri5rJxiWOT0Ar/6AfUXw==`
  615. // userInfo, err := weapp.DecryptUserInfo(sessionKey, rawData, encryptedData,signature, iv)
  616. // fmt.Println(userInfo)
  617. // fmt.Println(err)
  618. // fmt.Println("end")
  619. //}
  620. //func init() {
  621. // sessionKey:=`zkHYyjTv2kNQgXyIVYC3cQ==`
  622. // rowData:=`{nickName:rdluck,gender:1,language:zh_CN,city:Wuhan,province:Hubei,country:China,avatarUrl:https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTJGUvpic2UAQC8Zm8WZg5V9xJtdXDLHpS6VMiaxibzDEXyYoDsXa3F2sXiaegd5lhSbcwMHibwXqTzichww/132}`
  623. // encyData:=`3vg6rtKN2oqdOKRi9fV9sUgBQTgA9ndo2WHEtLSmKofLW4BFKr1AQdAeyzNtPNPIr73vt6hVUt2VzMLTeZWlS1CXBVON8xb5heVhF6RUxXtSbPje2BUYZ HjGthXZ1kkiXs89KD/SsZJ7V0YDz7RB9VQwUROLHz8mCXBXvFa j80BIO637M0wIgU1GQ1tlxoVKedV1Z85FMpSuqGEVPRwyzaVkBeSr6o5zhnMF/O2t4sHb2 mHYCh9i1ssPzpygeOsXzaR5IU/a52bDBHYSEhXi4G79dsTvTKPTOEbaeNOosxx aZiG UNDTZ9hI9tJHhdib0QTCtNhIQpgaEzaFSymj0Dnea1LZN/jx4AyiF U6GX7TOkSFyVNECLJ2HofHet3 Kw3eZ9g4SJHIXwmKUoyEXENjeZScXxs llnfskQEsz4Iibss05/23AS7q4hbTeRD0fsf1jU43qEYjvuyXEFQInKO2kmG1fX0QnFE6UsD5BFtjwUX2yhgrWCBdrrdrcnF5JQBDLtMxY8MGprd0A==`
  624. // sign:=`c70a5d08e8aec0b26a80078d1a6d46ae17acb46a`
  625. // iv:=`0 NP9YFMj3gURHG8wwHNgQ==`
  626. // userInfo,err:=weapp.DecryptUserInfo(sessionKey,rowData, encyData, sign, iv)
  627. // fmt.Println(err)
  628. // fmt.Println(userInfo)
  629. //}
  630. // @Title 更新微信token
  631. // @Description 更新微信token
  632. // @Success Ret=200 更新成功
  633. // @router /updateWxAccesstoken [get]
  634. func (this *WechatController) UpdateWxAccesstoken() {
  635. br := new(models.BaseResponse).Init()
  636. defer func() {
  637. this.Data["json"] = br
  638. this.ServeJSON()
  639. }()
  640. accessToken, err := models.GetWxAccessToken()
  641. if err != nil {
  642. utils.FileLog.Info("GetWxAccessToken Err:%s", err.Error())
  643. return
  644. }
  645. br.Data = accessToken
  646. br.Ret = 200
  647. br.Success = true
  648. }
  649. // @Title 微信登录小助手接口
  650. // @Description 微信登录小助手接口
  651. // @Param Code query string true "微信唯一编码code"
  652. // @Success 200 {object} models.WxLoginResp
  653. // @router /loginByxzs [get]
  654. func (this *WechatCommonController) WechatLoginByxzs() {
  655. br := new(models.BaseResponse).Init()
  656. defer func() {
  657. this.Data["json"] = br
  658. this.ServeJSON()
  659. }()
  660. code := this.GetString("Code")
  661. if code == "" {
  662. br.Msg = "参数错误"
  663. br.ErrMsg = "Code 为空"
  664. return
  665. }
  666. item, err := services.WxGetUserOpenIdByCodeXzs(code)
  667. if err != nil {
  668. br.Msg = "获取用户信息失败"
  669. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  670. return
  671. }
  672. if item.Errcode != 0 {
  673. br.Msg = "获取用户信息失败"
  674. br.ErrMsg = "获取access_token 失败 errcode:" + strconv.Itoa(item.Errcode) + " ;errmsg:" + item.Errmsg
  675. return
  676. }
  677. openId := item.Openid
  678. if openId == "" {
  679. br.Msg = "获取用户信息失败"
  680. br.ErrMsg = "获取openid失败,openid:" + item.Openid
  681. return
  682. }
  683. unionId := item.Unionid
  684. if unionId == "" {
  685. br.Msg = "获取用户信息失败"
  686. br.ErrMsg = "获取unionid失败,unionid:" + item.Openid
  687. return
  688. }
  689. total, err := models.GetCygxUserRecordCount(openId)
  690. if err != nil {
  691. br.Msg = "获取用户信息失败"
  692. br.ErrMsg = "查询数量失败,Err:" + err.Error()
  693. return
  694. }
  695. if total == 0 {
  696. items := new(models.CygxUserRecord)
  697. items.OpenId = openId
  698. items.UnionId = unionId
  699. items.CreateTime = time.Now()
  700. _, err = models.AddCygxUserRecord(items)
  701. if err != nil {
  702. br.Msg = "获取用户信息失败"
  703. br.ErrMsg = "添加openid失败,Err:" + err.Error()
  704. return
  705. }
  706. }
  707. br.Ret = 200
  708. br.Success = true
  709. br.Msg = "获取成功"
  710. br.Data = item
  711. }