user_login.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_mini_crm_ht/models"
  5. "eta/eta_mini_crm_ht/models/request"
  6. "eta/eta_mini_crm_ht/models/response"
  7. "eta/eta_mini_crm_ht/services"
  8. "eta/eta_mini_crm_ht/utils"
  9. "fmt"
  10. "time"
  11. )
  12. type UserLoginController struct {
  13. BaseCommonController
  14. }
  15. func ssoLogin(req request.UserLoginReq, br *models.BaseResponse) {
  16. if req.Code == "" {
  17. br.Msg = "code不能为空"
  18. return
  19. }
  20. ssoResp, err := services.SSOLogin(req.Code)
  21. utils.FileLog.Info(fmt.Sprintf("sso 登录请求结果:%s", ssoResp))
  22. sysUser, err := models.GetSysUserBySysUserName(ssoResp.UserName)
  23. if err != nil {
  24. br.ErrMsg = err.Error()
  25. br.Msg = "sso登录失败,获取用户信息失败"
  26. return
  27. }
  28. sysRole, err := models.GetSysRoleById(sysUser.SysRoleId)
  29. if err != nil {
  30. br.Msg = "登录失败"
  31. br.ErrMsg = "查询角色失败, Err:" + err.Error()
  32. return
  33. }
  34. account := utils.MD5(sysUser.SysUserName)
  35. token := utils.GenToken(account)
  36. sysSession := new(models.SysSession)
  37. sysSession.UserName = sysUser.SysUserName
  38. sysSession.SysUserId = sysUser.SysUserId
  39. sysSession.ExpiredTime = time.Now().AddDate(0, 0, 60)
  40. sysSession.CreatedTime = time.Now()
  41. sysSession.LastUpdatedTime = time.Now()
  42. sysSession.AccessToken = token
  43. err = sysSession.AddSysSession()
  44. if err != nil {
  45. br.Msg = "登录失败"
  46. br.ErrMsg = "新增session信息失败, Err:" + err.Error()
  47. return
  48. }
  49. resp := new(response.LoginResp)
  50. resp.Authorization = "authorization=" + token
  51. resp.SysUserName = sysUser.SysUserName
  52. resp.SysRealName = sysUser.SysRealName
  53. resp.SysUserId = sysUser.SysUserId
  54. resp.RoleName = sysRole.SysRoleName
  55. resp.RoleId = sysUser.SysRoleId
  56. //获取不可信的登录态,并将该登录态重置掉,不允许多次登录
  57. noTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN_NO_TRUST, sysUser.SysUserId)
  58. noTrustLoginId, _ := utils.Rc.RedisString(noTrustLoginKey)
  59. fmt.Println("noTrustLoginId:", noTrustLoginId)
  60. if noTrustLoginId != `` { // 如果存在不可信设备,那么将其下架
  61. oldNoTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, noTrustLoginId)
  62. utils.Rc.Put(oldNoTrustLoginKey, "0", time.Hour*24)
  63. }
  64. // 设置redis缓存,记录用户登录态
  65. loginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, sysSession.SysSessionId)
  66. utils.Rc.Put(loginKey, "1", time.Hour*24)
  67. utils.Rc.Put(noTrustLoginKey, sysSession.SysSessionId, time.Hour*24*60)
  68. br.Data = resp
  69. br.Ret = 200
  70. br.Success = true
  71. br.Msg = "登录成功"
  72. }
  73. // Login
  74. // @Title 用户登录
  75. // @Description 用户登录
  76. // @Param request body UserLoginReq true "type json string"
  77. // @Success 200 {object} models.LoginResp
  78. // @router /login [post]
  79. func (this *UserLoginController) Login() {
  80. br := new(models.BaseResponse).Init()
  81. defer func() {
  82. this.Data["json"] = br
  83. this.ServeJSON()
  84. }()
  85. var req request.UserLoginReq
  86. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  87. if err != nil {
  88. br.Msg = "参数错误"
  89. br.ErrMsg = "解析参数失败:" + err.Error()
  90. return
  91. }
  92. switch req.LoginType {
  93. case "sso":
  94. ssoLogin(req, br)
  95. case "password":
  96. login(req, br)
  97. default:
  98. ssoLogin(req, br)
  99. }
  100. }
  101. func login(req request.UserLoginReq, br *models.BaseResponse) {
  102. if req.UserName == "" {
  103. br.Msg = "请输入账号"
  104. return
  105. }
  106. if req.Password == "" {
  107. br.Msg = "请输入密码"
  108. return
  109. }
  110. sysUser, err := models.GetSysUserBySysUserName(req.UserName)
  111. if err != nil {
  112. if err.Error() == utils.ErrNoRow() {
  113. br.Msg = "登录失败, 账号或密码错误"
  114. return
  115. } else {
  116. br.Msg = "系统错误"
  117. br.ErrMsg = "系统错误" + err.Error()
  118. return
  119. }
  120. }
  121. sysRole, err := models.GetSysRoleById(sysUser.SysRoleId)
  122. if err != nil {
  123. br.Msg = "登录失败"
  124. br.ErrMsg = "查询角色失败, Err:" + err.Error()
  125. return
  126. }
  127. dbPass := utils.MD5(fmt.Sprintf("%s%s%s", sysUser.Password, utils.UserLoginSalt, req.ReqTime))
  128. if req.Password != dbPass {
  129. br.Msg = "登录失败, 账号或密码错误"
  130. return
  131. }
  132. account := utils.MD5(sysUser.SysUserName)
  133. token := utils.GenToken(account)
  134. sysSession := new(models.SysSession)
  135. sysSession.UserName = sysUser.SysUserName
  136. sysSession.SysUserId = sysUser.SysUserId
  137. sysSession.ExpiredTime = time.Now().AddDate(0, 0, 60)
  138. sysSession.CreatedTime = time.Now()
  139. sysSession.LastUpdatedTime = time.Now()
  140. sysSession.AccessToken = token
  141. err = sysSession.AddSysSession()
  142. if err != nil {
  143. br.Msg = "登录失败"
  144. br.ErrMsg = "新增session信息失败, Err:" + err.Error()
  145. return
  146. }
  147. resp := new(response.LoginResp)
  148. resp.Authorization = "authorization=" + token
  149. resp.SysUserName = sysUser.SysUserName
  150. resp.SysRealName = sysUser.SysRealName
  151. resp.SysUserId = sysUser.SysUserId
  152. resp.RoleName = sysRole.SysRoleName
  153. resp.RoleId = sysUser.SysRoleId
  154. // 获取不可信的登录态,并将该登录态重置掉,不允许多次登录
  155. noTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN_NO_TRUST, sysUser.SysUserId)
  156. noTrustLoginId, _ := utils.Rc.RedisString(noTrustLoginKey)
  157. fmt.Println("noTrustLoginId:", noTrustLoginId)
  158. if noTrustLoginId != `` { // 如果存在不可信设备,那么将其下架
  159. oldNoTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, noTrustLoginId)
  160. utils.Rc.Put(oldNoTrustLoginKey, "0", time.Hour*24)
  161. }
  162. // 设置redis缓存,记录用户登录态
  163. loginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, sysSession.SysSessionId)
  164. utils.Rc.Put(loginKey, "1", time.Hour*24)
  165. utils.Rc.Put(noTrustLoginKey, sysSession.SysSessionId, time.Hour*24*60)
  166. br.Data = resp
  167. br.Ret = 200
  168. br.Success = true
  169. br.Msg = "登录成功"
  170. }
  171. // AreaCodeList
  172. // @Title 手机号区号列表
  173. // @Description 手机号区号列表
  174. // @Success 200 Ret=200 获取成功
  175. // @router /area_code/list [get]
  176. func (this *UserLoginController) AreaCodeList() {
  177. br := new(models.BaseResponse).Init()
  178. defer func() {
  179. if br.ErrMsg == "" {
  180. br.IsSendEmail = false
  181. }
  182. this.Data["json"] = br
  183. this.ServeJSON()
  184. }()
  185. resp := make([]response.AreaCodeListResp, 0)
  186. confAuth, e := models.GetConfigDetailByCode(models.ConfAreaCodeListKey)
  187. if e != nil {
  188. br.Msg = "获取失败"
  189. br.ErrMsg = "获取手机号区号配置失败, Err: " + e.Error()
  190. return
  191. }
  192. if confAuth.ConfigValue == "" {
  193. br.Msg = "获取失败"
  194. br.ErrMsg = "手机号区号配置为空"
  195. return
  196. }
  197. if e := json.Unmarshal([]byte(confAuth.ConfigValue), &resp); e != nil {
  198. br.Msg = "获取失败"
  199. br.ErrMsg = "手机号区号配置有误"
  200. return
  201. }
  202. br.Data = resp
  203. br.Ret = 200
  204. br.Success = true
  205. br.Msg = "获取成功"
  206. }