mirror of
				https://github.com/dromara/RuoYi-Vue-Plus.git
				synced 2025-11-04 16:23:42 +08:00 
			
		
		
		
	update 优化 全局异常处理器 业务异常不输出具体堆栈信息 减少无用日志存储
This commit is contained in:
		@@ -12,6 +12,7 @@ import lombok.extern.slf4j.Slf4j;
 | 
			
		||||
import org.dromara.common.core.domain.R;
 | 
			
		||||
import org.dromara.common.core.exception.DemoModeException;
 | 
			
		||||
import org.dromara.common.core.exception.ServiceException;
 | 
			
		||||
import org.dromara.common.core.exception.base.BaseException;
 | 
			
		||||
import org.dromara.common.core.utils.StreamUtils;
 | 
			
		||||
import org.springframework.context.support.DefaultMessageSourceResolvable;
 | 
			
		||||
import org.springframework.validation.BindException;
 | 
			
		||||
@@ -77,18 +78,27 @@ public class GlobalExceptionHandler {
 | 
			
		||||
     */
 | 
			
		||||
    @ExceptionHandler(ServiceException.class)
 | 
			
		||||
    public R<Void> handleServiceException(ServiceException e, HttpServletRequest request) {
 | 
			
		||||
        log.error(e.getMessage(), e);
 | 
			
		||||
        log.error(e.getMessage());
 | 
			
		||||
        Integer code = e.getCode();
 | 
			
		||||
        return ObjectUtil.isNotNull(code) ? R.fail(code, e.getMessage()) : R.fail(e.getMessage());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 业务异常
 | 
			
		||||
     */
 | 
			
		||||
    @ExceptionHandler(BaseException.class)
 | 
			
		||||
    public R<Void> handleBaseException(BaseException e, HttpServletRequest request) {
 | 
			
		||||
        log.error(e.getMessage());
 | 
			
		||||
        return R.fail(e.getMessage());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 请求路径中缺少必需的路径变量
 | 
			
		||||
     */
 | 
			
		||||
    @ExceptionHandler(MissingPathVariableException.class)
 | 
			
		||||
    public R<Void> handleMissingPathVariableException(MissingPathVariableException e, HttpServletRequest request) {
 | 
			
		||||
        String requestURI = request.getRequestURI();
 | 
			
		||||
        log.error("请求路径中缺少必需的路径变量'{}',发生系统异常.", requestURI, e);
 | 
			
		||||
        log.error("请求路径中缺少必需的路径变量'{}',发生系统异常.", requestURI);
 | 
			
		||||
        return R.fail(String.format("请求路径中缺少必需的路径变量[%s]", e.getVariableName()));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -98,7 +108,7 @@ public class GlobalExceptionHandler {
 | 
			
		||||
    @ExceptionHandler(MethodArgumentTypeMismatchException.class)
 | 
			
		||||
    public R<Void> handleMethodArgumentTypeMismatchException(MethodArgumentTypeMismatchException e, HttpServletRequest request) {
 | 
			
		||||
        String requestURI = request.getRequestURI();
 | 
			
		||||
        log.error("请求参数类型不匹配'{}',发生系统异常.", requestURI, e);
 | 
			
		||||
        log.error("请求参数类型不匹配'{}',发生系统异常.", requestURI);
 | 
			
		||||
        return R.fail(String.format("请求参数类型不匹配,参数[%s]要求类型为:'%s',但输入值为:'%s'", e.getName(), e.getRequiredType().getName(), e.getValue()));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -127,7 +137,7 @@ public class GlobalExceptionHandler {
 | 
			
		||||
     */
 | 
			
		||||
    @ExceptionHandler(BindException.class)
 | 
			
		||||
    public R<Void> handleBindException(BindException e) {
 | 
			
		||||
        log.error(e.getMessage(), e);
 | 
			
		||||
        log.error(e.getMessage());
 | 
			
		||||
        String message = StreamUtils.join(e.getAllErrors(), DefaultMessageSourceResolvable::getDefaultMessage, ", ");
 | 
			
		||||
        return R.fail(message);
 | 
			
		||||
    }
 | 
			
		||||
@@ -137,7 +147,7 @@ public class GlobalExceptionHandler {
 | 
			
		||||
     */
 | 
			
		||||
    @ExceptionHandler(ConstraintViolationException.class)
 | 
			
		||||
    public R<Void> constraintViolationException(ConstraintViolationException e) {
 | 
			
		||||
        log.error(e.getMessage(), e);
 | 
			
		||||
        log.error(e.getMessage());
 | 
			
		||||
        String message = StreamUtils.join(e.getConstraintViolations(), ConstraintViolation::getMessage, ", ");
 | 
			
		||||
        return R.fail(message);
 | 
			
		||||
    }
 | 
			
		||||
@@ -147,7 +157,7 @@ public class GlobalExceptionHandler {
 | 
			
		||||
     */
 | 
			
		||||
    @ExceptionHandler(MethodArgumentNotValidException.class)
 | 
			
		||||
    public R<Void> handleMethodArgumentNotValidException(MethodArgumentNotValidException e) {
 | 
			
		||||
        log.error(e.getMessage(), e);
 | 
			
		||||
        log.error(e.getMessage());
 | 
			
		||||
        String message = e.getBindingResult().getFieldError().getDefaultMessage();
 | 
			
		||||
        return R.fail(message);
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user