LoginController.java 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. package com.template.controller;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.template.annotation.PassToken;
  4. import com.template.api.LoginControllerAPI;
  5. import com.template.common.utils.AesUtils;
  6. import com.template.common.utils.JWTUtil;
  7. import com.template.common.utils.RSAUtils;
  8. import com.template.common.utils.paramUtils;
  9. import com.template.config.MySecurity;
  10. import com.template.model.pojo.Admin;
  11. import com.template.model.pojo.PermissionSetting;
  12. import com.template.model.request.changePasswordRequest;
  13. import com.template.model.request.loginRequest;
  14. import com.template.model.result.CommonResult;
  15. import com.template.model.vo.LoginVO;
  16. import com.template.services.AdminService;
  17. import com.template.services.PermissionSettingService;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.validation.BindingResult;
  20. import org.springframework.web.bind.annotation.RequestBody;
  21. import org.springframework.web.bind.annotation.RestController;
  22. /**
  23. * @Author: binguo
  24. * @Date: 2023/7/5 星期三 9:28
  25. * @Description: com.template.controller
  26. * @Version: 1.0
  27. */
  28. @RestController
  29. public class LoginController implements LoginControllerAPI {
  30. @Autowired
  31. private AdminService adminService;
  32. @Autowired
  33. MySecurity mySecurity;
  34. @Autowired
  35. PermissionSettingService permissionSettingService;
  36. /**
  37. * 登录接口
  38. * @param loginRequest
  39. * account 账号
  40. * password 密码
  41. * @return
  42. *
  43. */
  44. @Override
  45. @PassToken
  46. public CommonResult Login(@RequestBody loginRequest loginRequest, BindingResult bindingResult) {
  47. if(loginRequest == null){
  48. return CommonResult.fail("请传递参数");
  49. }
  50. if (bindingResult.hasErrors()) {
  51. String st = paramUtils.getParamError(bindingResult);
  52. return CommonResult.fail(st);
  53. }
  54. Admin result = adminService.getAdminByAccount(loginRequest.getAccount());
  55. if(result == null){
  56. return CommonResult.fail("账号或密码错误");
  57. }
  58. try {
  59. // 传入的解密
  60. String decryptData = RSAUtils.decrypt(loginRequest.getPassword(),RSAUtils.getPrivateKey(mySecurity.privateKey));
  61. // 原密码解密
  62. String decrypt = RSAUtils.decrypt(result.getPassWord(), RSAUtils.getPrivateKey(mySecurity.privateKey));
  63. if(!decryptData.equals(decrypt)){
  64. return CommonResult.fail("密码错误");
  65. }
  66. String adminMenuId = result.getAdminMenuId();
  67. // 通过adminMenuId获取权限表的id
  68. LambdaQueryWrapper<PermissionSetting> wrapper=new LambdaQueryWrapper<>();
  69. wrapper.eq(PermissionSetting::getAdminMenuId,adminMenuId);
  70. PermissionSetting one = permissionSettingService.getOne(wrapper);
  71. // JSONObject jsonObject = new JSONObject();
  72. //// 房态
  73. // String houseStatusManagement = one.getHouseStatusManagement();
  74. // if (ObjectUtils.isEmpty(houseStatusManagement)) {
  75. // jsonObject.put("houseStatusManagement",0);
  76. // }else {
  77. // jsonObject.put("houseStatusManagement",1);
  78. // }
  79. //// 房型
  80. // String houseTypeManagement = one.getHouseTypeManagement();
  81. //
  82. // if (ObjectUtils.isEmpty(houseTypeManagement)) {
  83. // jsonObject.put("houseTypeManagement",0);
  84. // }else {
  85. // if (houseTypeManagement.contains("0")) {
  86. //
  87. // houseType.put("houseType",1);
  88. // houseType.put("housePrice",1);
  89. // jsonObject.put("houseTypeManagement",houseType);
  90. // }
  91. // }
  92. String token = JWTUtil.getAdminToken(result);
  93. LoginVO login = new LoginVO();
  94. login.setToken(token);
  95. login.setTokenTtl(JWTUtil.getExpired());
  96. login.setUserName(result.getName());
  97. login.setId(result.getId());
  98. login.setPermissionSettingId(one.getId());
  99. login.setUser_head(AesUtils.encrypt(result.getId()+""));
  100. login.setPermissionSetting(one);
  101. return CommonResult.ok("登录成功",login);
  102. }catch (Exception e){
  103. e.printStackTrace();
  104. return CommonResult.fail("密码错误");
  105. }
  106. }
  107. /**
  108. * 修改密码
  109. * @param cpr
  110. * oldPassword 旧密码
  111. * newPassword 新密码
  112. * confirmPassword 确认密码
  113. * @param bindingResult
  114. * @return
  115. */
  116. @Override
  117. public CommonResult ChangePassword(changePasswordRequest cpr, BindingResult bindingResult) {
  118. if (bindingResult.hasErrors()) {
  119. String st = paramUtils.getParamError(bindingResult);
  120. return CommonResult.fail(st);
  121. }
  122. Admin admin = adminService.getById(cpr.getAdminId());
  123. if(admin == null){
  124. return CommonResult.fail("当前账号不合法!");
  125. }
  126. try {
  127. // 新密码码解密
  128. String newPassWord = RSAUtils.decrypt(cpr.getNewPassword(), RSAUtils.getPrivateKey(mySecurity.privateKey));
  129. // 确认密码解密
  130. String confirmPassword = RSAUtils.decrypt(cpr.getConfirmPassword(), RSAUtils.getPrivateKey(mySecurity.privateKey));
  131. if(!newPassWord.equals(confirmPassword)){
  132. return CommonResult.fail("确认密码和新密码不一致!");
  133. }
  134. // 传入的旧解密
  135. String decryptData = RSAUtils.decrypt(cpr.getOldPassword(), RSAUtils.getPrivateKey(mySecurity.privateKey));
  136. if (newPassWord.equals(decryptData)) {
  137. return CommonResult.fail("新密码和旧密码一致!");
  138. }
  139. // 原密码解密
  140. String decrypt = RSAUtils.decrypt(admin.getPassWord(), RSAUtils.getPrivateKey(mySecurity.privateKey));
  141. if (!decryptData.equals(decrypt)) {
  142. return CommonResult.fail("原密码错误!");
  143. }
  144. admin.setPassWord(cpr.getNewPassword());
  145. boolean update = adminService.updateById(admin);
  146. if (update) {
  147. return CommonResult.ok("修改成功");
  148. }
  149. }catch (Exception e){
  150. e.printStackTrace();
  151. }
  152. return CommonResult.fail();
  153. }
  154. }