spring @ExceptionHandler+@ControllerAdvice异常拦截处理类

1.BadRequestExceptionHandler  通用异常拦截处理类

使用@ExceptionHandler,可以处理异常, 但是仅限于当前Controller中处理异常, @ControllerAdvice可以配置basePackage下的所有controller. 所以结合两者使用,就可以处理全局的异常了

/**
 * 通用异常拦截处理类(通过切面的方式默认拦截所有的controller异常)
 */
@ControllerAdvice
@ResponseBody
public class BadRequestExceptionHandler {
	private static final Logger logger = LoggerFactory.getLogger(BadRequestExceptionHandler.class);

	/**
	 * 校验错误拦截处理
	 *
	 * @param exception
	 *            错误信息集合
	 * @return 错误信息
	 */
	@ExceptionHandler(MethodArgumentNotValidException.class)
	public Object validationBodyException(MethodArgumentNotValidException exception) {
		Rsp rsp = new Rsp();
		BindingResult result = exception.getBindingResult();
		if (result.hasErrors()) {
			List<ObjectError> errors = result.getAllErrors();
			errors.forEach(p -> {
				FieldError fieldError = (FieldError) p;
				logger.error("数据校验失败 : 对象 {" + fieldError.getObjectName() + "},参数{" + fieldError.getField() + "},错误信息{"
						+ fieldError.getDefaultMessage() + "}");
				rsp.setRspDesc(fieldError.getDefaultMessage());
			});
		}
		return WebUtil.resp(rsp);
	}

	/**
	 * 参数类型转换错误
	 *
	 * @param exception
	 *            错误
	 * @return 错误信息
	 */
	@ExceptionHandler(HttpMessageConversionException.class)
	public Object parameterTypeException(HttpMessageConversionException exception) {

		logger.error(exception.getCause().getLocalizedMessage());
		// return ServiceResult.error("类型转换错误");
		return "类型转换错误";

	}

}

2.WebUtil类

public class WebUtil {

	private static Logger logger = LoggerFactory.getLogger(RenewalNoticeController.class);

	@SuppressWarnings("rawtypes")
	public static Object resp(Rsp rsp) {
		ServiceResponse<Object> serviceResponse = new ServiceResponse<>();
		serviceResponse.setRsp(rsp);
		String result = JSONObject.toJSONString(serviceResponse);
		logger.info("NNNN" + result);
		return serviceResponse;
	}
}

 3.ServiceResponse 服务应答类

/**
 * 服务应答类
 */
public class ServiceResponse<DATA> {
	private static Logger logger = LoggerFactory.getLogger(ServiceResponse.class);

	@ApiModelProperty(name = "STATUS", value = "服务请求结果编码", required = true, example = "0000")
	@JsonProperty("STATUS")
	@JSONField(name = "STATUS")
	private String status;
	@ApiModelProperty(name = "MSG", value = "服务请求结果描述", required = true, example = "服务调用成功!")
	@JsonProperty("MSG")
	@JSONField(name = "MSG")
	private String msg;
	@ApiModelProperty(name = "RSP", value = "服务返回业务数据", required = true)
	@JsonProperty("RSP")
	@JSONField(name = "RSP")
	private Rsp<DATA> rsp;


	/**
	 * 服务成功调用应答信息
	 * 
	 * @param rsp
	 * @return ServiceResponse
	 */
	public ServiceResponse getSuccessResponse(Rsp<DATA> rsp) {
		this.setStatus(ServiceConstant.STATUS_SUCCESS);
		this.setMsg(ServiceConstant.MSG_SUCCESS);
		this.setRsp(rsp);
		return this;
	}

	/**
	 * 服务其他错误返回结果
	 * 
	 * @param errorStatus
	 * @param errorMsg
	 * @param rsp
	 * @return
	 */
	public ServiceResponse getErrorResponse(String errorStatus, String errorMsg, Rsp<DATA> rsp) {
		this.setStatus(errorStatus);
		this.setMsg(errorMsg);
		this.setRsp(rsp);
		return this;
	}

	public String getStatus() {
		return status;
	}

	public void setStatus(String status) {
		this.status = status;
	}

	public String getMsg() {
		return msg;
	}

	public void setMsg(String msg) {
		this.msg = msg;
	}

	public Rsp<DATA> getRsp() {
		return rsp;
	}

	public void setRsp(Rsp<DATA> rsp) {
		this.rsp = rsp;
	}	
}

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,很高兴能回答您的问题。 首先,让我们了解一下 @ControllerAdvice 注解。它是 Spring MVC 框架提供的一种全局异常处理机制,可以让我们在一个地方集中处理所有 Controller 抛出的异常。 使用 @ControllerAdvice 注解的类可以包含多个 @ExceptionHandler 注解的方法,每个方法处理不同的异常类型。当 Controller 抛出异常时,Spring 会根据异常类型找到对应的 @ExceptionHandler 方法进行处理。 以下是一个简单的 @ControllerAdvice 示例: ```java @ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(Exception.class) public ResponseEntity<String> handleException(Exception e) { return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Something went wrong!"); } @ExceptionHandler(MyCustomException.class) public ResponseEntity<String> handleMyCustomException(MyCustomException e) { return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(e.getMessage()); } } ``` 在上面的例子中,我们定义了两个 @ExceptionHandler 方法,分别处理 Exception 和 MyCustomException 类型的异常。 如果您想要更细粒度地处理异常,可以在 @ExceptionHandler 注解中指定具体的异常类型,如下所示: ```java @ExceptionHandler({IOException.class, SQLException.class}) public void handleIOExceptionOrSQLException() { // ... } ``` 另外,@ControllerAdvice 还支持自定义返回值类型和异常解析器,具体可以参考 Spring 官方文档。 最后,关于统一处理异常,除了使用 @ControllerAdvice,我们还可以使用 Spring Boot 提供的 ErrorController 接口或实现自己的异常处理器。 希望能对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值