LoginController.java 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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. TmUser tmUser = tmUserService.getByUserName(request.getPhoneNum());
  52. if(tmUser == null){
  53. throw new BusinessException(ResultCode.PASSWORD_ERROR);
  54. }
  55. if(tmUser.getStatus() == 0){
  56. throw new BusinessException(ResultCode.USER_NOT_LOGIN_PERM);
  57. }
  58. List<TmDepartment> deptList = tmDepartmentService.getSonByDeptId(request.getDeptId());
  59. if(deptList == null || deptList.size() <=0){
  60. throw new BusinessException(ResultCode.DEPT_NOT_EXITS);
  61. }
  62. List<String> deptIds = deptList.stream().map(TmDepartment::getId).collect(Collectors.toList());
  63. if(!deptIds.contains(tmUser.getDeptId())){
  64. throw new BusinessException(ResultCode.PASSWORD_ERROR);
  65. }
  66. //对前端传的密码解密
  67. FdkkResponse<FdkkLoginVo> fdkkLoginVo = fdKKClient.fdkkLogin(request);
  68. if(fdkkLoginVo.getCode() == 0){
  69. FdkkLoginVo data = fdkkLoginVo.getData();
  70. StpUtil.login(tmUser.getId(), SaLoginConfig
  71. .setExtra("userId",tmUser.getId())
  72. //.setExtra("fdToken",data.getToken())
  73. .setExtra("userName",data.getUser().getUserName())
  74. .setExtra("deptId",tmUser.getDeptId())
  75. .setExtra("nickName",data.getUser().getNickName()));
  76. data.setFdToken(data.getToken());
  77. data.setToken(StpUtil.getTokenValue());
  78. tmUserService.setRoleAndPermToRedis(tmUser);
  79. data.setTmUser(tmUser);
  80. redisUtil.set(String.format(RedisKeyUtil.fusionLoginToken,data.getToken()),JSONObject.toJSONString(data),RedisKeyUtil.tokenTime);
  81. redisUtil.set(String.format(RedisKeyUtil.fusionLoginUser,tmUser.getId()),JSONObject.toJSONString(data),RedisKeyUtil.tokenTime);
  82. return ResultData.ok(data);
  83. }
  84. return ResultData.error(fdkkLoginVo.getCode(),fdkkLoginVo.getMsg());
  85. }
  86. @PostMapping("/fdLogout")
  87. public ResultData fdLogout(){
  88. String fusionLoginToken = String.format(RedisKeyUtil.fusionLoginToken,StpUtil.getTokenValue());
  89. String fusionLoginUser = String.format(RedisKeyUtil.fusionLoginUser,StpUtil.getLoginId());
  90. String fdToken = String.format(RedisKey.TOKEN_V3,fdService.getFdToken());
  91. redisUtil.del(fusionLoginToken);
  92. redisUtil.del(fusionLoginUser);
  93. redisUtil.del(fdToken);
  94. StpUtil.logout();
  95. return ResultData.ok();
  96. }
  97. }