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


最近和领导说不想做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: [email protected]
* @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出来,具体可以自己测试一下。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章