LoginController.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package com.fdkankan.fusion.controller;
  2. import cn.dev33.satoken.stp.SaLoginConfig;
  3. import cn.dev33.satoken.stp.StpUtil;
  4. import cn.hutool.captcha.CaptchaUtil;
  5. import cn.hutool.captcha.LineCaptcha;
  6. import com.alibaba.excel.EasyExcel;
  7. import com.alibaba.fastjson.JSONObject;
  8. import com.fdkankan.fusion.common.ResultCode;
  9. import com.fdkankan.fusion.common.ResultData;
  10. import com.fdkankan.fusion.common.util.RedisKeyUtil;
  11. import com.fdkankan.fusion.entity.TmDepartment;
  12. import com.fdkankan.fusion.entity.TmUser;
  13. import com.fdkankan.fusion.exception.BusinessException;
  14. import com.fdkankan.fusion.httpClient.FdService;
  15. import com.fdkankan.fusion.httpClient.client.FdKKClient;
  16. import com.fdkankan.fusion.httpClient.request.FdkkLoginRequest;
  17. import com.fdkankan.fusion.httpClient.response.FdkkLoginVo;
  18. import com.fdkankan.fusion.httpClient.response.FdkkResponse;
  19. import com.fdkankan.fusion.service.ITmDepartmentService;
  20. import com.fdkankan.fusion.service.ITmUserService;
  21. import com.fdkankan.redis.constant.RedisKey;
  22. import com.fdkankan.redis.util.RedisUtil;
  23. import org.apache.commons.lang3.StringUtils;
  24. import org.springframework.beans.factory.annotation.Autowired;
  25. import org.springframework.web.bind.annotation.*;
  26. import javax.annotation.Resource;
  27. import java.util.List;
  28. import java.util.stream.Collectors;
  29. @RestController
  30. @RequestMapping
  31. public class LoginController extends BaseController{
  32. @Resource
  33. FdKKClient fdKKClient;
  34. @Autowired
  35. RedisUtil redisUtil;
  36. @Autowired
  37. ITmUserService tmUserService;
  38. @Autowired
  39. FdService fdService;
  40. @Autowired
  41. ITmDepartmentService tmDepartmentService;
  42. @PostMapping("/fdLogin")
  43. public ResultData fdLogin(@RequestBody FdkkLoginRequest request){
  44. if(StringUtils.isBlank(request.getPhoneNum()) || StringUtils.isBlank(request.getPassword())
  45. || StringUtils.isBlank(request.getCode()) || StringUtils.isBlank(request.getDeptId())){
  46. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  47. }
  48. if(!redisUtil.hasKey(String.format(RedisKeyUtil.loginAuthCode,request.getCode()))){
  49. throw new BusinessException(ResultCode.LOGIN_AUTH_NOT_EXIST);
  50. }
  51. redisUtil.del(String.format(RedisKeyUtil.loginAuthCode,request.getCode()));
  52. TmUser tmUser = tmUserService.getByUserName(request.getPhoneNum());
  53. if(tmUser == null){
  54. throw new BusinessException(ResultCode.PASSWORD_ERROR);
  55. }
  56. if(tmUser.getStatus() == 0){
  57. throw new BusinessException(ResultCode.USER_NOT_LOGIN_PERM);
  58. }
  59. //超管除外
  60. if(!tmUser.getDeptId().equals("0")){
  61. List<TmDepartment> deptList = tmDepartmentService.getSonByDeptId(request.getDeptId());
  62. if(deptList == null || deptList.size() <=0){
  63. throw new BusinessException(ResultCode.DEPT_NOT_EXITS);
  64. }
  65. List<String> deptIds = deptList.stream().map(TmDepartment::getId).collect(Collectors.toList());
  66. if(!deptIds.contains(tmUser.getDeptId())){
  67. throw new BusinessException(ResultCode.PASSWORD_ERROR);
  68. }
  69. }
  70. //对前端传的密码解密
  71. FdkkResponse<FdkkLoginVo> fdkkLoginVo = fdKKClient.fdkkLogin(request);
  72. if(fdkkLoginVo.getCode() == 0){
  73. FdkkLoginVo data = fdkkLoginVo.getData();
  74. StpUtil.login(tmUser.getId(), SaLoginConfig
  75. .setExtra("userId",tmUser.getId())
  76. //.setExtra("fdToken",data.getToken())
  77. .setExtra("userName",data.getUser().getUserName())
  78. .setExtra("deptId",tmUser.getDeptId())
  79. .setExtra("nickName",data.getUser().getNickName()));
  80. data.setFdToken(data.getToken());
  81. data.setToken(StpUtil.getTokenValue());
  82. tmUserService.setRoleAndPermToRedis(tmUser);
  83. data.setTmUser(tmUser);
  84. redisUtil.set(String.format(RedisKeyUtil.fusionLoginToken,data.getToken()),JSONObject.toJSONString(data),RedisKeyUtil.tokenTime);
  85. redisUtil.set(String.format(RedisKeyUtil.fusionLoginUser,tmUser.getId()),JSONObject.toJSONString(data),RedisKeyUtil.tokenTime);
  86. return ResultData.ok(data);
  87. }
  88. return ResultData.error(fdkkLoginVo.getCode(),fdkkLoginVo.getMsg());
  89. }
  90. @PostMapping("/fdLogout")
  91. public ResultData fdLogout(){
  92. String fusionLoginToken = String.format(RedisKeyUtil.fusionLoginToken,StpUtil.getTokenValue());
  93. String fusionLoginUser = String.format(RedisKeyUtil.fusionLoginUser,StpUtil.getLoginId());
  94. String fdToken = String.format(RedisKey.TOKEN_V3,fdService.getFdToken());
  95. redisUtil.del(fusionLoginToken);
  96. redisUtil.del(fusionLoginUser);
  97. redisUtil.del(fdToken);
  98. StpUtil.logout();
  99. return ResultData.ok();
  100. }
  101. }