LoginController.java 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. package com.template.controller;
  2. import com.template.annotation.PassToken;
  3. import com.template.api.LoginControllerAPI;
  4. import com.template.model.enumModel.eStatu;
  5. import com.template.model.pojo.RepairAdmin;
  6. import com.template.model.request.loginRequest;
  7. import com.template.model.result.CommonResult;
  8. import com.template.model.vo.LoginVO;
  9. import com.template.services.RepairAdminService;
  10. import com.template.common.utils.AesUtils;
  11. import com.template.common.utils.paramUtils;
  12. import com.template.common.utils.JWTUtil;
  13. import org.springframework.beans.factory.annotation.Autowired;
  14. import org.springframework.validation.BindingResult;
  15. import org.springframework.web.bind.annotation.RequestBody;
  16. import org.springframework.web.bind.annotation.RequestHeader;
  17. import org.springframework.web.bind.annotation.RestController;
  18. /**
  19. * @Author: binguo
  20. * @Date: 2023/7/5 星期三 9:28
  21. * @Description: com.template.controller
  22. * @Version: 1.0
  23. */
  24. @RestController
  25. public class LoginController implements LoginControllerAPI {
  26. @Autowired
  27. private RepairAdminService repairAdminService;
  28. /**
  29. * 查看系统版本号
  30. * @return
  31. */
  32. @Override
  33. @PassToken
  34. public CommonResult queryReduce() {
  35. return CommonResult.ok("当前系统版本为:1V");
  36. }
  37. /**
  38. * 注册接口
  39. * @param registerdo
  40. * account 账号
  41. * password 密码
  42. * username 昵称
  43. * phone 手机号
  44. * @return
  45. */
  46. @Override
  47. @PassToken
  48. public CommonResult Register(@RequestBody RepairAdmin registerdo, BindingResult bindingResult) {
  49. if(registerdo == null){
  50. return CommonResult.fail("请传递参数");
  51. }
  52. if (bindingResult.hasErrors()) {
  53. String st = paramUtils.getParamError(bindingResult);
  54. return CommonResult.fail(st);
  55. }
  56. int result = 0;
  57. try{
  58. result = repairAdminService.insertRepairAdmin(registerdo);
  59. }catch (Exception e){
  60. if(e.getCause().getMessage().contains("'repair_admin.account_un'")){
  61. return CommonResult.fail("该账号已存在!");
  62. }
  63. return CommonResult.fail("系统异常,注册失败!");
  64. }
  65. if(result > 0){
  66. return CommonResult.ok("注册成功!");
  67. }
  68. return CommonResult.fail("注册失败!");
  69. }
  70. /**
  71. * 登录接口
  72. * @param loginRequest
  73. * account 账号
  74. * password 密码
  75. * @return
  76. *
  77. */
  78. @Override
  79. @PassToken
  80. public CommonResult Login(@RequestBody loginRequest loginRequest, BindingResult bindingResult) {
  81. if(loginRequest == null){
  82. return CommonResult.fail("请传递参数");
  83. }
  84. if (bindingResult.hasErrors()) {
  85. String st = paramUtils.getParamError(bindingResult);
  86. return CommonResult.fail(st);
  87. }
  88. RepairAdmin result = repairAdminService.getRepairByAccount(loginRequest.getAccount());
  89. if(result == null){
  90. return CommonResult.fail("账号或密码错误");
  91. }
  92. if(result.getStatu() == eStatu.Freeze.getValue()){
  93. return CommonResult.fail("该账号已被冻结");
  94. }
  95. String encPassword = AesUtils.encrypt(loginRequest.getPassword());
  96. if(!encPassword.equals(result.getPassword())){
  97. return CommonResult.fail("密码错误");
  98. }
  99. String token = JWTUtil.getToken(result);
  100. LoginVO login = new LoginVO();
  101. login.setToken(token);
  102. login.setTokenTtl(JWTUtil.getExpired());
  103. login.setUserName(result.getUsername());
  104. login.setUserhead(AesUtils.encrypt(result.getId()));
  105. return CommonResult.ok("登录成功",login);
  106. }
  107. /**
  108. * 修改密码
  109. * @param cpr
  110. * oldPassword 旧密码
  111. * newPassword 新密码
  112. * confirmPassword 确认密码
  113. * @param userhead
  114. * @param bindingResult
  115. * @return
  116. */
  117. @Override
  118. public CommonResult ChangePassword(com.repair.model.request.changePasswordRequest cpr, @RequestHeader("user_head") String userhead, BindingResult bindingResult) {
  119. if (bindingResult.hasErrors()) {
  120. String st = paramUtils.getParamError(bindingResult);
  121. return CommonResult.fail(st);
  122. }
  123. if(!cpr.getNewPassword().equals(cpr.getConfirmPassword())){
  124. return CommonResult.fail("确认密码和新密码不一致!");
  125. }
  126. String userID = AesUtils.decrypt(userhead);
  127. RepairAdmin operateData = repairAdminService.getRepairById(userID);
  128. if(operateData == null){
  129. return CommonResult.fail("当前账号不合法!");
  130. }
  131. if(operateData.getStatu() == eStatu.Freeze.getValue()){
  132. return CommonResult.fail("该账号已被冻结");
  133. }
  134. if(!AesUtils.encrypt(cpr.getOldPassword()).equals(operateData.getPassword())){
  135. return CommonResult.fail("原密码错误!");
  136. }
  137. RepairAdmin ra = new RepairAdmin();
  138. ra.setId(userID);
  139. ra.setPassword(AesUtils.encrypt(cpr.getNewPassword()));
  140. int result = repairAdminService.updateRepairAdmin(ra);
  141. return result > 0 ? CommonResult.ok("修改成功") : CommonResult.fail("修改失败");
  142. }
  143. }