Browse Source

modify:

1. 修改登录异常权限捕获;
tags/24090601
WendyYang 4 months ago
parent
commit
4567b188f0
14 changed files with 114 additions and 105 deletions
  1. +39
    -0
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/checker/UserLoginChecker.java
  2. +4
    -16
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/code/AuthCodeLoginUserDetailService.java
  3. +6
    -6
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/credential/CredentialAuthFilter.java
  4. +2
    -2
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/credential/CredentialAuthProvider.java
  5. +4
    -4
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/credential/CredentialLoginUserDetailService.java
  6. +2
    -12
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/mh/MhLoginUserDetailService.java
  7. +20
    -0
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/exception/BizLoginException.java
  8. +11
    -7
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/handler/DefaultExpiredSessionStrategy.java
  9. +13
    -9
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/handler/DefaultLoginFailureHandler.java
  10. +11
    -8
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/handler/DefaultLoginSuccessHandler.java
  11. +0
    -17
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/validate/CommonLoginException.java
  12. +0
    -24
      hz-pm-api/src/main/java/com/hz/pm/api/user/security/validate/DingQrLoginException.java
  13. +1
    -0
      hz-pm-api/src/main/resources/application-dev.yml
  14. +1
    -0
      hz-pm-api/src/main/resources/application-prod.yml

+ 39
- 0
hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/checker/UserLoginChecker.java View File

@@ -0,0 +1,39 @@
package com.hz.pm.api.user.security.auth.checker;

import cn.hutool.core.collection.CollUtil;
import com.hz.pm.api.user.model.enumeration.UserAvailableEnum;
import com.hz.pm.api.user.security.exception.BizLoginException;
import com.hz.pm.api.user.security.model.UserFullInfoDTO;

import java.util.Objects;

/**
* <p>
* UserLoginHelper
* </p>
*
* @author WendyYang
* @since 09:21 2024/9/6
*/
public class UserLoginChecker {

private UserLoginChecker() {
}

public static void checkLoginAuth(UserFullInfoDTO user) {
if (Objects.isNull(user)) {
throw new BizLoginException("用户不存在");
}
if (user.getMhUnitId() == null || user.getMhUnitId() < 0) {
throw BizLoginException.wrap("暂无登录权限");
}
if (UserAvailableEnum.DISABLE.equals(user.getAvailable())) {
throw new BizLoginException("账号已禁用");
}
if (CollUtil.isEmpty(user.getUserRoleList())) {
throw new BizLoginException("账号未配置角色");
}
}


}

+ 4
- 16
hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/code/AuthCodeLoginUserDetailService.java View File

@@ -1,20 +1,16 @@
package com.hz.pm.api.user.security.auth.code; package com.hz.pm.api.user.security.auth.code;




import cn.hutool.core.collection.CollUtil;
import com.hz.pm.api.common.helper.UserInfoHelper; import com.hz.pm.api.common.helper.UserInfoHelper;
import com.hz.pm.api.user.convert.UserInfoConvertor; import com.hz.pm.api.user.convert.UserInfoConvertor;
import com.hz.pm.api.user.model.enumeration.UserAvailableEnum;
import com.hz.pm.api.user.security.auth.checker.UserLoginChecker;
import com.hz.pm.api.user.security.model.UserFullInfoDTO; import com.hz.pm.api.user.security.model.UserFullInfoDTO;
import com.hz.pm.api.user.security.model.UserInfoDetails; import com.hz.pm.api.user.security.model.UserInfoDetails;
import com.hz.pm.api.user.security.validate.CommonLoginException;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;


import java.util.Objects;

/** /**
* <p> * <p>
* AuthCodeLoginUserDetailService * AuthCodeLoginUserDetailService
@@ -32,17 +28,9 @@ public class AuthCodeLoginUserDetailService implements UserDetailsService {
@Override @Override
public UserInfoDetails loadUserByUsername(String username) throws UsernameNotFoundException { public UserInfoDetails loadUserByUsername(String username) throws UsernameNotFoundException {
Long userId = Long.parseLong(username); Long userId = Long.parseLong(username);
UserFullInfoDTO ufi = userInfoHelper.getUserFullInfo(userId);
if (Objects.isNull(ufi)) {
throw new UsernameNotFoundException("用户不存在");
}
if (UserAvailableEnum.DISABLE.equals(ufi.getAvailable())) {
throw new CommonLoginException("账号已禁用");
}
if (CollUtil.isEmpty(ufi.getUserRoleList())) {
throw new CommonLoginException("账号未配置角色");
}
return UserInfoConvertor.convert(ufi);
UserFullInfoDTO user = userInfoHelper.getUserFullInfo(userId);
UserLoginChecker.checkLoginAuth(user);
return UserInfoConvertor.convert(user);
} }


} }

+ 6
- 6
hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/credential/CredentialAuthFilter.java View File

@@ -3,7 +3,7 @@ package com.hz.pm.api.user.security.auth.credential;
import com.ningdatech.basic.exception.BizException; import com.ningdatech.basic.exception.BizException;
import com.hz.pm.api.user.model.enumeration.LoginTypeEnum; import com.hz.pm.api.user.model.enumeration.LoginTypeEnum;
import com.hz.pm.api.user.security.model.WebRequestDetails; import com.hz.pm.api.user.security.model.WebRequestDetails;
import com.hz.pm.api.user.security.validate.CommonLoginException;
import com.hz.pm.api.user.security.exception.BizLoginException;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.springframework.http.HttpMethod; import org.springframework.http.HttpMethod;
import org.springframework.security.authentication.AuthenticationServiceException; import org.springframework.security.authentication.AuthenticationServiceException;
@@ -60,8 +60,8 @@ public class CredentialAuthFilter extends AbstractAuthenticationProcessingFilter
CredentialAuthToken authRequest = new CredentialAuthToken(identifier, credential, loginType); CredentialAuthToken authRequest = new CredentialAuthToken(identifier, credential, loginType);
authRequest.setDetails(new WebRequestDetails(request)); authRequest.setDetails(new WebRequestDetails(request));
return this.getAuthenticationManager().authenticate(authRequest); return this.getAuthenticationManager().authenticate(authRequest);
} catch (CommonLoginException e) {
throw new CommonLoginException(e.getMessage());
} catch (BizLoginException e) {
throw new BizLoginException(e.getMessage());
} catch (BadCredentialsException | BizException e) { } catch (BadCredentialsException | BizException e) {
throw new BadCredentialsException(e.getMessage()); throw new BadCredentialsException(e.getMessage());
} catch (AuthenticationException e) { } catch (AuthenticationException e) {
@@ -80,19 +80,19 @@ public class CredentialAuthFilter extends AbstractAuthenticationProcessingFilter
switch (loginTypeEnum) { switch (loginTypeEnum) {
case DING_QR_LOGIN: { case DING_QR_LOGIN: {
if (StringUtils.isBlank(credential)) { if (StringUtils.isBlank(credential)) {
throw new CommonLoginException("浙政钉扫码登陆 授权码 不能为空 credential");
throw new BizLoginException("浙政钉扫码登陆 授权码 不能为空 credential");
} }
} }
break; break;
case USERNAME_PASSWORD_LOGIN: { case USERNAME_PASSWORD_LOGIN: {
if (StringUtils.isBlank(identifier) || StringUtils.isBlank(credential)) { if (StringUtils.isBlank(identifier) || StringUtils.isBlank(credential)) {
throw new CommonLoginException("账号密码登陆 账号密码不能为空 identifier credential");
throw new BizLoginException("账号密码登陆 账号密码不能为空 identifier credential");
} }
} }
break; break;
case PHONE_VERIFICATION_CODE_LOGIN: { case PHONE_VERIFICATION_CODE_LOGIN: {
if (StringUtils.isBlank(identifier) || StringUtils.isBlank(credential)) { if (StringUtils.isBlank(identifier) || StringUtils.isBlank(credential)) {
throw new CommonLoginException("手机号验证码登陆 手机号或验证码不能为空 identifier credential");
throw new BizLoginException("手机号验证码登陆 手机号或验证码不能为空 identifier credential");
} }
} }
break; break;


+ 2
- 2
hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/credential/CredentialAuthProvider.java View File

@@ -5,7 +5,7 @@ import com.hz.pm.api.sms.helper.VerifyCodeCheckHelper;
import com.hz.pm.api.user.model.enumeration.LoginTypeEnum; import com.hz.pm.api.user.model.enumeration.LoginTypeEnum;
import com.hz.pm.api.user.security.auth.constants.SessionTimeConst; import com.hz.pm.api.user.security.auth.constants.SessionTimeConst;
import com.hz.pm.api.user.security.auth.constants.UserDetailsServiceConstant; import com.hz.pm.api.user.security.auth.constants.UserDetailsServiceConstant;
import com.hz.pm.api.user.security.validate.CommonLoginException;
import com.hz.pm.api.user.security.exception.BizLoginException;
import com.ningdatech.basic.exception.BizException; import com.ningdatech.basic.exception.BizException;
import org.springframework.security.authentication.AuthenticationProvider; import org.springframework.security.authentication.AuthenticationProvider;
import org.springframework.security.authentication.BadCredentialsException; import org.springframework.security.authentication.BadCredentialsException;
@@ -46,7 +46,7 @@ public class CredentialAuthProvider implements AuthenticationProvider {
// 校验短信验证码 // 校验短信验证码
boolean verificationResult = verifyCodeCheckHelper.verification(VerificationCodeType.LOGIN, principal, credentials); boolean verificationResult = verifyCodeCheckHelper.verification(VerificationCodeType.LOGIN, principal, credentials);
if (!verificationResult && !SessionTimeConst.UNIVERSAL_VERIFICATION_CODE.equals(credentials)) { if (!verificationResult && !SessionTimeConst.UNIVERSAL_VERIFICATION_CODE.equals(credentials)) {
throw new CommonLoginException("验证码错误");
throw new BizLoginException("验证码错误");
} }
} }
user = userDetailsService.loadUserByUsername(principal + UserDetailsServiceConstant.USER_DETAILS_SERVICE_SEPARATOR + loginTypeEnum.name()); user = userDetailsService.loadUserByUsername(principal + UserDetailsServiceConstant.USER_DETAILS_SERVICE_SEPARATOR + loginTypeEnum.name());


+ 4
- 4
hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/credential/CredentialLoginUserDetailService.java View File

@@ -8,7 +8,7 @@ import com.hz.pm.api.user.manage.UserInfoManage;
import com.hz.pm.api.user.security.auth.constants.UserDetailsServiceConstant; import com.hz.pm.api.user.security.auth.constants.UserDetailsServiceConstant;
import com.hz.pm.api.user.security.model.UserFullInfoDTO; import com.hz.pm.api.user.security.model.UserFullInfoDTO;
import com.hz.pm.api.user.security.model.UserInfoDetails; import com.hz.pm.api.user.security.model.UserInfoDetails;
import com.hz.pm.api.user.security.validate.CommonLoginException;
import com.hz.pm.api.user.security.exception.BizLoginException;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.security.core.userdetails.UsernameNotFoundException;
@@ -39,7 +39,7 @@ public class CredentialLoginUserDetailService implements UserDetailsService {
case PHONE_VERIFICATION_CODE_LOGIN: { case PHONE_VERIFICATION_CODE_LOGIN: {
userFullInfo = userInfoManage.queryUserInfoInPhoneNoAuth(username); userFullInfo = userInfoManage.queryUserInfoInPhoneNoAuth(username);
if (Objects.isNull(userFullInfo)) { if (Objects.isNull(userFullInfo)) {
throw new CommonLoginException("该手机号未绑定用户");
throw new BizLoginException("该手机号未绑定用户");
} }
} }
break; break;
@@ -54,7 +54,7 @@ public class CredentialLoginUserDetailService implements UserDetailsService {
case DING_QR_LOGIN: { case DING_QR_LOGIN: {
userFullInfo = userInfoManage.queryUserInfoInAccountIdAuth(username); userFullInfo = userInfoManage.queryUserInfoInAccountIdAuth(username);
if (Objects.isNull(userFullInfo)) { if (Objects.isNull(userFullInfo)) {
throw new CommonLoginException("浙政钉账号无法登陆");
throw new BizLoginException("浙政钉账号无法登陆");
} }
} }
break; break;
@@ -64,7 +64,7 @@ public class CredentialLoginUserDetailService implements UserDetailsService {
} }


if (UserAvailableEnum.DISABLE.equals(userFullInfo.getAvailable())) { if (UserAvailableEnum.DISABLE.equals(userFullInfo.getAvailable())) {
throw new CommonLoginException("该账号已被禁用");
throw new BizLoginException("该账号已被禁用");
} }
return UserInfoConvertor.convert(userFullInfo); return UserInfoConvertor.convert(userFullInfo);
} }


+ 2
- 12
hz-pm-api/src/main/java/com/hz/pm/api/user/security/auth/mh/MhLoginUserDetailService.java View File

@@ -1,21 +1,18 @@
package com.hz.pm.api.user.security.auth.mh; package com.hz.pm.api.user.security.auth.mh;




import cn.hutool.core.collection.CollUtil;
import cn.hutool.json.JSONUtil; import cn.hutool.json.JSONUtil;
import com.hz.pm.api.common.helper.UserInfoHelper; import com.hz.pm.api.common.helper.UserInfoHelper;
import com.hz.pm.api.user.convert.UserInfoConvertor; import com.hz.pm.api.user.convert.UserInfoConvertor;
import com.hz.pm.api.user.security.auth.checker.UserLoginChecker;
import com.hz.pm.api.user.security.model.UserFullInfoDTO; import com.hz.pm.api.user.security.model.UserFullInfoDTO;
import com.hz.pm.api.user.security.model.UserInfoDetails; import com.hz.pm.api.user.security.model.UserInfoDetails;
import com.ningdatech.basic.exception.BizException;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;


import static com.hz.pm.api.user.model.enumeration.UserAvailableEnum.DISABLE;

/** /**
* <p> * <p>
* AgentLoginUserDetailService * AgentLoginUserDetailService
@@ -34,14 +31,7 @@ public class MhLoginUserDetailService implements UserDetailsService {
@Override @Override
public UserInfoDetails loadUserByUsername(String username) throws UsernameNotFoundException { public UserInfoDetails loadUserByUsername(String username) throws UsernameNotFoundException {
UserFullInfoDTO userInfo = userInfoHelper.getUserFullInfoByMhUserIdOrOpenId(username); UserFullInfoDTO userInfo = userInfoHelper.getUserFullInfoByMhUserIdOrOpenId(username);
if (userInfo == null || DISABLE.equals(userInfo.getAvailable())) {
throw BizException.wrap("用户不存在或已被禁用");
}
if (userInfo.getMhUnitId() == null
|| userInfo.getMhUnitId() <= 0
|| CollUtil.isEmpty(userInfo.getUserRoleList())) {
throw BizException.wrap("用户暂无登录权限");
}
UserLoginChecker.checkLoginAuth(userInfo);
log.info("登录用户为:{}", JSONUtil.toJsonStr(userInfo)); log.info("登录用户为:{}", JSONUtil.toJsonStr(userInfo));
return UserInfoConvertor.convert(userInfo); return UserInfoConvertor.convert(userInfo);
} }


+ 20
- 0
hz-pm-api/src/main/java/com/hz/pm/api/user/security/exception/BizLoginException.java View File

@@ -0,0 +1,20 @@
package com.hz.pm.api.user.security.exception;

import org.springframework.security.core.AuthenticationException;

/**
* @author liuxinxin
* @date 2023/3/24 上午11:47
* 通用登陆错误
*/
public class BizLoginException extends AuthenticationException {

public BizLoginException(String message) {
super(message);
}

public static BizLoginException wrap(String message) {
return new BizLoginException(message);
}

}

+ 11
- 7
hz-pm-api/src/main/java/com/hz/pm/api/user/security/handler/DefaultExpiredSessionStrategy.java View File

@@ -5,6 +5,7 @@ import com.hz.pm.api.user.security.errorcode.AuthErrorCodeEnum;
import com.ningdatech.basic.model.ApiResponse; import com.ningdatech.basic.model.ApiResponse;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.security.web.session.SessionInformationExpiredEvent; import org.springframework.security.web.session.SessionInformationExpiredEvent;
import org.springframework.security.web.session.SessionInformationExpiredStrategy; import org.springframework.security.web.session.SessionInformationExpiredStrategy;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
@@ -13,10 +14,13 @@ import javax.servlet.http.HttpServletResponse;
import java.io.IOException; import java.io.IOException;


/** /**
* @Author LiuXinXin
* @Date 2020/8/20 11:15 上午
* @Version 1.0
**/
* <p>
* DefaultExpiredSessionStrategy
* </p>
*
* @author WendyYang
* @since 09:33 2024/9/6
*/
@Component @Component
@RequiredArgsConstructor @RequiredArgsConstructor
public class DefaultExpiredSessionStrategy implements SessionInformationExpiredStrategy { public class DefaultExpiredSessionStrategy implements SessionInformationExpiredStrategy {
@@ -27,11 +31,11 @@ public class DefaultExpiredSessionStrategy implements SessionInformationExpiredS




@Override @Override
public void onExpiredSessionDetected(SessionInformationExpiredEvent sessionInformationExpiredEvent)
public void onExpiredSessionDetected(SessionInformationExpiredEvent event)
throws IOException { throws IOException {
HttpServletResponse response = sessionInformationExpiredEvent.getResponse();
HttpServletResponse response = event.getResponse();
response.setStatus(HttpStatus.UNAUTHORIZED.value()); response.setStatus(HttpStatus.UNAUTHORIZED.value());
response.setContentType("application/json;charset=UTF-8");
response.setContentType(MediaType.APPLICATION_JSON_VALUE);
response.getWriter().write(objectMapper.writeValueAsString(SESSION_EXPIRED)); response.getWriter().write(objectMapper.writeValueAsString(SESSION_EXPIRED));
} }




+ 13
- 9
hz-pm-api/src/main/java/com/hz/pm/api/user/security/handler/DefaultLoginFailureHandler.java View File

@@ -1,29 +1,33 @@
package com.hz.pm.api.user.security.handler; package com.hz.pm.api.user.security.handler;


import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.ningdatech.basic.model.ApiResponse;
import com.hz.pm.api.user.security.errorcode.AuthErrorCodeEnum; import com.hz.pm.api.user.security.errorcode.AuthErrorCodeEnum;
import com.hz.pm.api.user.security.validate.CommonLoginException;
import com.hz.pm.api.user.security.exception.BizLoginException;
import com.ningdatech.basic.model.ApiResponse;
import lombok.RequiredArgsConstructor;
import org.springframework.security.authentication.BadCredentialsException; import org.springframework.security.authentication.BadCredentialsException;
import org.springframework.security.core.AuthenticationException; import org.springframework.security.core.AuthenticationException;
import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.security.web.authentication.SimpleUrlAuthenticationFailureHandler; import org.springframework.security.web.authentication.SimpleUrlAuthenticationFailureHandler;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;


import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import java.io.IOException; import java.io.IOException;


/** /**
* @Author LiuXinXin
* @Date 2020/8/3 8:32 下午
* @Version 1.0
**/
* <p>
* DefaultLoginFailureHandler
* </p>
*
* @author WendyYang
* @since 09:36 2024/9/6
*/
@RequiredArgsConstructor
@Component("defaultLoginFailureHandler") @Component("defaultLoginFailureHandler")
public class DefaultLoginFailureHandler extends SimpleUrlAuthenticationFailureHandler { public class DefaultLoginFailureHandler extends SimpleUrlAuthenticationFailureHandler {


private final ObjectMapper objectMapper = new ObjectMapper();
private final ObjectMapper objectMapper;


@Override @Override
public void onAuthenticationFailure(HttpServletRequest request, HttpServletResponse response, public void onAuthenticationFailure(HttpServletRequest request, HttpServletResponse response,
@@ -33,7 +37,7 @@ public class DefaultLoginFailureHandler extends SimpleUrlAuthenticationFailureHa
String errorMsg; String errorMsg;
// 所有的认证异常都可以在这里添加,目前只支持用户名密码错误异常 // 所有的认证异常都可以在这里添加,目前只支持用户名密码错误异常


if (exception instanceof CommonLoginException) {
if (exception instanceof BizLoginException) {
errorCode = 400; errorCode = 400;
errorMsg = exception.getMessage(); errorMsg = exception.getMessage();
} else if (exception instanceof BadCredentialsException || exception instanceof UsernameNotFoundException) { } else if (exception instanceof BadCredentialsException || exception instanceof UsernameNotFoundException) {


+ 11
- 8
hz-pm-api/src/main/java/com/hz/pm/api/user/security/handler/DefaultLoginSuccessHandler.java View File

@@ -2,7 +2,7 @@ package com.hz.pm.api.user.security.handler;


import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.ningdatech.basic.model.ApiResponse; import com.ningdatech.basic.model.ApiResponse;
import org.springframework.beans.factory.annotation.Autowired;
import lombok.RequiredArgsConstructor;
import org.springframework.context.annotation.Primary; import org.springframework.context.annotation.Primary;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.security.core.Authentication; import org.springframework.security.core.Authentication;
@@ -14,16 +14,19 @@ import javax.servlet.http.HttpServletResponse;
import java.io.IOException; import java.io.IOException;


/** /**
* @Author LiuXinXin
* @Date 2020/8/3 8:32 下午
* @Version 1.0
**/
@Component("defaultLoginSuccessHandler")
* <p>
* DefaultLoginSuccessHandler
* </p>
*
* @author WendyYang
* @since 09:35 2024/9/6
*/
@Primary @Primary
@RequiredArgsConstructor
@Component("defaultLoginSuccessHandler")
public class DefaultLoginSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler { public class DefaultLoginSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler {


@Autowired
private ObjectMapper objectMapper;
private final ObjectMapper objectMapper;


@Override @Override
public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response,


+ 0
- 17
hz-pm-api/src/main/java/com/hz/pm/api/user/security/validate/CommonLoginException.java View File

@@ -1,17 +0,0 @@
package com.hz.pm.api.user.security.validate;

import org.springframework.security.core.AuthenticationException;

/**
* @author liuxinxin
* @date 2023/3/24 上午11:47
* 通用登陆错误
*/
public class CommonLoginException extends AuthenticationException {

public CommonLoginException(String message) {
super(message);
}


}

+ 0
- 24
hz-pm-api/src/main/java/com/hz/pm/api/user/security/validate/DingQrLoginException.java View File

@@ -1,24 +0,0 @@
package com.hz.pm.api.user.security.validate;

import lombok.Data;
import lombok.EqualsAndHashCode;

/**
* @author liuxinxin
* @date 2023/3/24 上午11:47
* 浙政钉扫码登陆错误
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class DingQrLoginException extends RuntimeException {

private final Integer code;

private final String message;

public DingQrLoginException(int code, String message) {
this.code = code;
this.message = message;
}

}

+ 1
- 0
hz-pm-api/src/main/resources/application-dev.yml View File

@@ -2,6 +2,7 @@ server:
port: 8002 port: 8002
servlet: servlet:
context-path: /hzpm context-path: /hzpm
shutdown: graceful


spring: spring:
mvc: mvc:


+ 1
- 0
hz-pm-api/src/main/resources/application-prod.yml View File

@@ -6,6 +6,7 @@ server:
tomcat: tomcat:
threads: threads:
max: 600 max: 600
shutdown: graceful
spring: spring:
mvc: mvc:
pathmatch: pathmatch:


Loading…
Cancel
Save