项目中使用SPRING AOP方式统一捕获异常

本文详细介绍了如何使用Spring AOP技术优化Java框架的异常处理机制,包括配置动态异常捕获、统一异常记录和避免重复捕获不确定异常。通过实践示例,展示了如何在业务代码中使用try-catch结构,并利用AopExceptionHandler类输出异常信息,从而提高代码的健壮性和维护性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


最近和领导说不想做Java开发(本来公司属我代码编写速度快,领导不肯放手),于是让我将现有的框架清理一下,搭建一个通用框架让开发人员方便使用,以下是主要优化方式:
1.
异常统一捕获:
传统程序中我们都是使用try{}catch(Exception e){ //输出异常信息}来捕获异常,这样做的缺点是:对于不确定异常未捕获,如对于一段业务程序,开发者知道没有错误,但对于编译器来说可能就会出错,如内存不足等之类的不肯定错误。现在我们可以通过 SPRINGAOP切入机制来动态捕获,主要配置如下:
注意:由于Struts2SPRING使用的动态代理机制不同,不能切入到Aciton中,故配置advice参数时不能切入到Action的方法中去

<!--
设置SPRING AOP动态捕获异常 1设定为自动代理 2负责记录有异常发生时的信息 3 对指定类的任何方法有效 -->
<!-- -->
<bean id="autoProxyCreator"

class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" />
<bean id="exceptionHandler"
class="com.datadriver.common.util.exception.aop.AopExceptionHandler" />
<!-- 这里配置切入点,可以为正则表达式 .*DAOImpl\.delete.* -->
<bean id="exceptionHandlereAdvisor"

class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">
<property name="advice">
<ref bean="exceptionHandler" />
</property>
<property name="patterns">
<list>
<!-- 切入包名中含impl字符的类主要为了捕获实现接口的类 -->
<value>.*impl*.*</value>

</list>
</property>
</bean>


其中类AopExceptionHandler

/**
* @author: zhengjianbo/Ram

* @Email: zhengjianbo2@hotmail.com
* @Company: DataDriver©2010/www.datadriver.com.cn
* @Action: 负责异常处理的Advice 使用Throw通知类型来实现Advice
* @DATE: 2010-9-3-
上午12:09:10
*/
public class AopExceptionHandler implements ThrowsAdvice

{
/**
* 重写afterThrowing()方法
*

* @param method 执行方法
* @param args
执行参数
* @param target
执行实体
* @param subclass
父类
* @throws Throwable
异常
*/
public void afterThrowing(Method method, Object[] args
, Object target,
Throwable subclass) throws Throwable
{

DataDriverLog.log.info("\r\n>>>>>\r\n执行:"+method.getName()+"时发生异常:"
+subclass+"\r\n<<<<<");//
输出异常信息
}

}


在具体使用时要注意:必须使用try{}catch(Exception e){} 对业务代码进行处理,如添加一条记录发生错误:
try{
//
添加记录成功的代码处理
}catch(Exception e){
//
添加记录失败的代码处理,
//
类似 alert("添加失败"); 的效果
}
而异常信息则通过afterThrowing方法输出来,无需再在catch当中System.out.println出来,具体可以自己测试一下。

### 使用 Spring AOP `@AfterThrowing` 注解捕获异常 为了利用 `@AfterThrowing` 注解来捕获并处理应用程序中的异常,需创建一个切面类,并在其中定义带有此注解的方法。该方法会在被拦截的方法抛出特定类型的异常时触发。 #### 创建 Aspect 类 首先,确保项目已引入了 `spring-boot-starter-aop` 依赖项[^2]: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> <version>2.1.4.RELEASE</version> </dependency> ``` 接着,编写一个方面(Aspect)类用于捕捉异常: ```java import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Aspect; import org.springframework.stereotype.Component; @Aspect @Component public class ExceptionHandlingAspect { /** * 当com.example.service包下的任何服务层组件内的任意公共成员函数发生异常时, * 将会调用本方法进行统一的日志记录或其他业务操作。 */ @AfterThrowing( pointcut = "execution(* com.example.service..*.*(..))", throwing = "exception" ) public void logException(Throwable exception) { System.err.println("An error occurred: " + exception.getMessage()); // 可在此处添加更多复杂的错误处理逻辑,如发送邮件报警、写入数据库等 } } ``` 上述代码片段展示了如何配置切入点表达式以及指定要监听的异常对象名称参数 `throwing="exception"`。每当匹配的服务层方法抛出了未被捕获异常实例时,就会自动回调 `logException()` 方法来进行相应的处理工作[^1]。 此外,还可以进一步定制化异常处理器的行为模式,例如只针对某些具体的异常类型做出反应;或是结合其他AOP通知机制共同作用于同一个连接点之上等等[^3]。 #### 测试效果 假设存在如下简单的Service接口及其实现类: ```java @Service public class SampleServiceImpl implements SampleService { @Override public String performOperation() throws RuntimeException { throw new RuntimeException("Simulated runtime failure"); } } ``` 当调用了 `performOperation()` 并引发了运行时异常后,控制台将会输出由 `ExceptionHandlerAspect.logException()` 所打印的信息:“An error occurred: Simulated runtime failure”。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值