java实现全局异常机制

先上自己的代码,后整理下原理知识。

下面是自己实现的全局异常机制

1.继承Exception,自定义异常类

​
package com.zichen.xhkq.exception;

/**
 * 
 * <p>Title: CustomException</p>
 * <p>Description: 系统自定义的异常类型,实际开发中可能要定义多种异常类型</p>
 * @author	CNZZ
 * @version 1.0
 */
public class CustomException extends Exception {
	
	/**
	 * 
	 */
	private static final long serialVersionUID = 5819174480253773214L;
	//异常信息
	private String message;
	
	public CustomException(String message){
		super(message);
		this.message = message;
		
	}

	public String getMessage() {
		return message;
	}

	public void setMessage(String message) {
		this.message = message;
	}
	
}

​

2.实现HandlerExceptionResolver,自定义异常处理器,可以判断处理自定义异常和系统异常,可以跳转异常页面

package com.zichen.xhkq.exception;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.ModelAndView;

/**
 * 
 * <p>Title: CustomExceptionResolver</p>
 * <p>Description: 自定义异常处理器</p>
 * @author	CNZZ
 * @version 1.0
 */
public class CustomExceptionResolver implements HandlerExceptionResolver  {

	//前端控制器DispatcherServlet在进行HandlerMapping、调用HandlerAdapter执行Handler过程中,如果遇到异常就会执行此方法
	//handler最终要执行的Handler,它的真实身份是HandlerMethod
	//Exception ex就是接收到异常信息
	@Override
	public ModelAndView resolveException(HttpServletRequest request,
			HttpServletResponse response, Object handler, Exception ex) {
		//输出异常
		ex.printStackTrace();
		
		//统一异常处理代码
		//针对系统自定义的CustomException异常,就可以直接从异常类中获取异常信息,将异常处理在错误页面展示
		//异常信息
		String message = null;
		CustomException customException = null;
		//如果ex是系统 自定义的异常,直接取出异常信息
		if(ex instanceof CustomException){
			customException = (CustomException)ex;
		}else{
			//针对非CustomException异常,对这类重新构造成一个CustomException,异常信息为“未知错误”
			customException = new CustomException("未知错误");
		}
		
		//错误 信息
		message = customException.getMessage();
		
		request.setAttribute("message", message);

		
		try {
			//转向到错误 页面
			request.getRequestDispatcher("/error.jsp").forward(request, response);
		} catch (ServletException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		return new ModelAndView();
	}

}

3.配置javaBean

<!--全局异常处理 -->
    <bean id="customExceptionResolver" class="com.zichen.xhkq.exception.CustomExceptionResolver" />

原理知识梳理(感谢各位的分享)

1 、Java异常分类

Java把异常当做对象来处理。Throwable是所有错误或异常的超类。Throwable类有两个直接子类:Error类和Exception类。
1、Error是指java运行时系统的内部错误和资源耗尽错误,是程序无法处理的异常,应用程序不会抛出该类对象。
2、Exception是程序本身可以处理的异常,应尽可能去处理这些异常。Exception分两类,一个是运行时异常RuntimeException,一个是检查异常CheckedException。
3、CheckedException一般是外部错误,这种异常都发生在编译阶段,Java编译器会强制程序去捕获此类异常。
4、RuntimeException是那些可能在Java 虚拟机正常运行期间抛出的异常的超类。这种错误是由程序员引起的错误,可以修正代码解决。

2、异常处理

在J2EE项目的开发中,不管是对底层的数据库操作过程,还是业务层的处理过程,还是控制层的处理过程,都不可避免会遇到各种可预知的、不可预知的异常需要处理。每个过程都单独处理异常,系统的代码耦合度高,工作量大且不好统一,维护的工作量也很大。 那么,能不能将所有类型的异常处理从各处理过程解耦出来,这样既保证了相关处理过程的功能较单一,也实现了异常信息的统一处理和维护?答案是肯定的。下面将介绍使用Spring MVC统一处理异常的解决和实现过程

  • 使用Spring MVC提供的SimpleMappingExceptionResolver
  • 实现Spring的异常处理接口HandlerExceptionResolver 自定义自己的异常处理器
  • 使用@ExceptionHandler注解实现异常处理

 

相关博客资源链接:

https://www.jb51.net/article/110776.htm    详解Spring全局异常处理的三种方式

https://testerhome.com/topics/12058     Java 代码中的全局异常处理

https://blog.youkuaiyun.com/XlxfyzsFdblj/article/details/80835013  Java全局异常处理

https://blog.youkuaiyun.com/lveliu/article/details/51768635 JAVA 后台全局异常控制

 

 

 

### Java全局异常处理的实现方式 在Java中,可以通过`@ControllerAdvice`注解来实现全局异常处理机制。这种机制允许开发者集中管理整个应用程序中的异常捕获和响应逻辑。 #### 使用@ControllerAdvice实现全局异常处理 通过定义一个带有`@ControllerAdvice`注解的类,可以拦截所有控制器方法抛出的异常并提供统一的错误响应。下面是一个完整的示例: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.ResponseBody; @ControllerAdvice(basePackages = "com.example.controller") public class GlobalExceptionHandler { private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class); /** * 处理通用Exception的情况 */ @ExceptionHandler(Exception.class) @ResponseBody public String handleException(HttpServletRequest request, Exception e) { log.error("发生未知异常!", e); return "{\"code\":\"-1\", \"message\":\"系统异常\"}"; } /** * 自定义业务异常处理 */ @ExceptionHandler(BusinessException.class) @ResponseBody public String businessExceptionHandler(BusinessException ex) { log.warn("业务异常:" + ex.getMessage()); return "{\"code\":\"0\", \"message\":\"" + ex.getMessage() + "\"}"; } } ``` 此代码片段展示了如何创建一个全局异常处理器[^1]。它能够捕捉到所有的未被捕获的运行时异常,并返回JSON格式的错误消息给客户端。 #### 定义自定义异常 为了更精确地控制不同的错误场景,通常会定义一系列自定义异常类。这些异常可以根据具体的应用需求扩展标准的`RuntimeException`类。例如: ```java package com.example.exceptions; public class BusinessException extends RuntimeException { public BusinessException(String message) { super(message); } } public class NotFoundException extends RuntimeException { public NotFoundException(String message) { super(message); } } ``` 以上代码提供了两个简单的自定义异常例子:一个是表示业务逻辑错误的`BusinessException`;另一个则是当资源找不到时使用的`NotFoundException`[^2]。 #### 日志记录的重要性 日志对于调试生产环境下的问题至关重要,在上面的例子中可以看到每次异常被触发的时候都会调用logger对象记录下相应的信息。这有助于后续排查问题以及了解系统的健康状态。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值