package com.qianwen.core.log.error; import java.util.Set; import javax.servlet.Servlet; import javax.validation.ConstraintViolation; import javax.validation.ConstraintViolationException; import org.hibernate.validator.internal.engine.path.PathImpl; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.qianwen.core.tool.api.R; import com.qianwen.core.tool.api.ResultCode; import com.qianwen.core.tool.utils.StringUtil; import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication; import org.springframework.context.annotation.Configuration; import org.springframework.core.annotation.Order; import org.springframework.dao.DuplicateKeyException; import org.springframework.http.HttpStatus; import org.springframework.http.converter.HttpMessageNotReadableException; import org.springframework.validation.BindException; import org.springframework.validation.BindingResult; import org.springframework.validation.FieldError; import org.springframework.web.HttpMediaTypeNotAcceptableException; import org.springframework.web.HttpMediaTypeNotSupportedException; import org.springframework.web.HttpRequestMethodNotSupportedException; import org.springframework.web.bind.MethodArgumentNotValidException; import org.springframework.web.bind.MissingServletRequestParameterException; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.ResponseStatus; import org.springframework.web.bind.annotation.RestControllerAdvice; import org.springframework.web.method.annotation.MethodArgumentTypeMismatchException; import org.springframework.web.servlet.DispatcherServlet; import org.springframework.web.servlet.NoHandlerFoundException; @RestControllerAdvice @Configuration(proxyBeanMethods = false) @ConditionalOnClass({Servlet.class, DispatcherServlet.class}) @Order(Integer.MIN_VALUE) @ConditionalOnWebApplication(type = ConditionalOnWebApplication.Type.SERVLET) /* loaded from: blade-starter-log-9.3.0.0-SNAPSHOT.jar:org/springblade/core/log/error/RestExceptionTranslator.class */ public class RestExceptionTranslator { private static final Logger log = LoggerFactory.getLogger(RestExceptionTranslator.class); @ExceptionHandler({DuplicateKeyException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(DuplicateKeyException e) { log.error("重复主键", e); return R.fail(ResultCode.FAILURE, "唯一键冲突"); } @ExceptionHandler({MissingServletRequestParameterException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(MissingServletRequestParameterException e) { log.warn("缺少请求参数", e.getMessage()); String message = String.format("缺少必要的请求参数: %s", e.getParameterName()); return R.fail(ResultCode.PARAM_MISS, message); } @ExceptionHandler({MethodArgumentTypeMismatchException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(MethodArgumentTypeMismatchException e) { log.warn("请求参数格式错误", e.getMessage()); String message = String.format("请求参数格式错误: %s", e.getName()); return R.fail(ResultCode.PARAM_TYPE_ERROR, message); } @ExceptionHandler({MethodArgumentNotValidException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(MethodArgumentNotValidException e) { log.warn("参数验证失败", e.getMessage()); return handleError(e.getBindingResult()); } @ExceptionHandler({BindException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(BindException e) { log.warn("参数绑定失败", e.getMessage()); return handleError(e.getBindingResult()); } private R handleError(BindingResult result) { FieldError error = result.getFieldError(); String message = String.format("%s:%s", error.getField(), error.getDefaultMessage()); return R.fail(ResultCode.PARAM_BIND_ERROR, message); } @ExceptionHandler({ConstraintViolationException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(ConstraintViolationException e) { /* log.warn("参数验证失败", e.getMessage()); Set> violations = e.getConstraintViolations(); ConstraintViolation violation = violations.iterator().next(); String path = violation.getPropertyPath().getLeafNode().getName(); String message = String.format("%s:%s", path, violation.getMessage()); return R.fail(ResultCode.PARAM_VALID_ERROR, message); */ log.warn("参数验证失败", e.getMessage()); Set> violations = e.getConstraintViolations(); ConstraintViolation violation = violations.iterator().next(); //String path = violation.getPropertyPath().getLeafNode().getName(); String path = ((PathImpl)violation.getPropertyPath()).getLeafNode().getName(); String message = String.format("%s:%s", new Object[] { path, violation.getMessage() }); return R.fail(ResultCode.PARAM_VALID_ERROR, message); } @ExceptionHandler({NoHandlerFoundException.class}) @ResponseStatus(HttpStatus.NOT_FOUND) public R handleError(NoHandlerFoundException e) { log.error("404没找到请求:{}", e.getMessage()); return R.fail(ResultCode.NOT_FOUND, e.getMessage()); } @ExceptionHandler({HttpMessageNotReadableException.class}) @ResponseStatus(HttpStatus.BAD_REQUEST) public R handleError(HttpMessageNotReadableException e) { log.error("消息不能读取:{}", e.getMessage()); return R.fail(ResultCode.MSG_NOT_READABLE, e.getMessage()); } @ExceptionHandler({HttpRequestMethodNotSupportedException.class}) @ResponseStatus(HttpStatus.METHOD_NOT_ALLOWED) public R handleError(HttpRequestMethodNotSupportedException e) { log.error("不支持当前请求方法:{}", e.getMessage()); return R.fail(ResultCode.METHOD_NOT_SUPPORTED, e.getMessage()); } @ExceptionHandler({HttpMediaTypeNotSupportedException.class}) @ResponseStatus(HttpStatus.UNSUPPORTED_MEDIA_TYPE) public R handleError(HttpMediaTypeNotSupportedException e) { log.error("不支持当前媒体类型:{}", e.getMessage()); return R.fail(ResultCode.MEDIA_TYPE_NOT_SUPPORTED, e.getMessage()); } @ExceptionHandler({HttpMediaTypeNotAcceptableException.class}) @ResponseStatus(HttpStatus.UNSUPPORTED_MEDIA_TYPE) public R handleError(HttpMediaTypeNotAcceptableException e) { String message = e.getMessage() + " " + StringUtil.join(e.getSupportedMediaTypes()); log.error("不接受的媒体类型:{}", message); return R.fail(ResultCode.MEDIA_TYPE_NOT_SUPPORTED, message); } }