spring AOP的异常拦截
来源:互联网 发布:淘宝上明星周边 编辑:程序博客网 时间:2024/05/21 16:40
springaopexceptionuserobjectdao
系统的异常处理机制是衡量一个系统设计的关键因素,良好的异常处理机制能在系统出现异常时准确的找到问题的所在。
spring aop对异常的处理有良好的支持。spring 提供了一个接口 ThrowsAdvice,该接口里面没有任何方法,但是实现类里面必须的实现
afterThrowing(Method method, Object[] args, Object target, RuntimeException throwable) 或者
afterThrowing(RuntimeException throwable)
如果需要记录发生异常方法的详细信息,则实现第一个方法就行,如果只记录发生的异常,实现第二个方法就ok!
那么异常的处理应该在什么位置来做处理呢?
一般我们的系统都应该有以下几个层次:Action--->Service---->DAO
DAO负责直接和数据库打交道,也是发生异常频率较高的地方,而service只是调用DAO所提供给外面的接口,action里面大部分的操作也是调用service的服务,再加上少数其他的逻辑,这部分的异常可以单独处理!下面我们主要关心DAO层的异常处理。
1、定义接口
- package com.beckham.dao;
- import java.util.List;
- import com.beckham.model.User;
- /**
- * @author Owner
- * Jan 19, 2010 10:15:32 PM
- *
- * struts2
- * com.beckham.dao
- * UserDAO.java
- */
- public interface UserDAO {
- public boolean userExsit(String username)throws Exception;
- public User findById(int id)throws Exception;
- public List<User> queryUser(String hql,int beginIndex)throws Exception;
- public void saveUser(User user)throws Exception;
- public int gettotalSize(String hql)throws Exception ;
- }
2、实现
- package com.beckham.daoimp;
- import java.util.List;
- import com.beckham.dao.SuperDAO;
- import com.beckham.dao.UserDAO;
- import com.beckham.model.User;
- import com.beckham.util.PropertyUtil;
- /**
- * @author Owner
- * Jan 19, 2010 10:15:50 PM
- *
- * struts2
- * com.beckham.daoimp
- * UserDAOImp.java
- */
- public class UserDAOImpextends SuperDAOimplements UserDAO {
- public User findById(int id)throws Exception {
- User user = null;
- try {
- user = (User) this.getHibernateTemplate().get(User.class, id);
- } catch (Exception e) {
- e.printStackTrace();
- throw new Exception("主键查询用户失败", e);
- }
- return user;
- }
- public void saveUser(User user)throws Exception {
- try {
- this.getHibernateTemplate().save(user);
- } catch (Exception e) {
- e.printStackTrace();
- throw new Exception("增加用户失败", e);
- }
- }
- @SuppressWarnings("unchecked")
- public List<User> queryUser(String hql,int beginIndex)throws Exception {
- try {
- return (List<User>)this.getHibernateTemplate().getSessionFactory()
- .getCurrentSession().createQuery(hql).setFirstResult(
- beginIndex).setMaxResults(
- PropertyUtil.getPageSize()).list();
- } catch (Exception e) {
- e.printStackTrace();
- throw new Exception("查询用户出现异常", e);
- }
- }
- public boolean userExsit(String username)throws Exception {
- boolean bl = true;
- String hql = "from User where username='" + username +"'";
- if (queryUser(hql,0).size() ==0) {
- bl = false;
- }
- return bl;
- }
- public int gettotalSize(String hql)throws Exception {
- int totalsize = 0;
- try {
- totalsize = Integer.parseInt(this.getHibernateTemplate().find(hql)
- .get(0).toString());
- } catch (Exception e) {
- e.printStackTrace();
- throw new Exception("查询用户总数失败", e);
- }
- return totalsize;
- }
- }
这里需要说明的是,这里的异常我没有细致的分类,都是throws Exception。
service层的代码就省略了,因为只是调用DAO层的方法,下面来写异常的拦截
- package com.beckham.aop;
- import java.lang.reflect.Method;
- import org.springframework.aop.ThrowsAdvice;
- /**
- * @author Owner Jan 18, 2010 2:37:10 PM 处理DAO层的异常 struts2 com.beckham.aop
- * ExceptionLog.java
- */
- public class ExceptionLogimplements ThrowsAdvice {
- /**
- * Owner
- * 参数解释 Method method 执行的方法
- * Object[] args 方法参数
- * Object target 代理的目标对象
- * Throwable throwable 产生的异常
- * Jan 18, 2010 3:21:46 PM
- */
- public void afterThrowing(Method method, Object[] args, Object target,
- RuntimeException throwable) {
- System.out.println("产生异常的方法名称: " + method.getName());
- for(Object o:args){
- System.out.println("方法的参数: " + o.toString());
- }
- System.out.println("代理对象: " + target.getClass().getName());
- System.out.println("抛出的异常: " + throwable.getMessage()+">>>>>>>"
- + throwable.getCause());
- System.out.println("异常详细信息: "+throwable.fillInStackTrace());
- }
- }
最后当然就是在配置文件里面配置了
- <beanid="log"class="com.beckham.aop.LogAdvice"></bean>
- <bean id="exceptionLog"class="com.beckham.aop.ExceptionLog"></bean>
- <!-- beanName自动代理 -->
- <bean id="logAdvice"
- class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
- <propertyname="beanNames">
- <list>
- <value>userDAO</value>
- </list>
- </property>
- <propertyname="interceptorNames">
- <list>
- <value>log</value>
- <value>exceptionLog</value>
- </list>
- </property>
- </bean>
到此,通过spring AOP拦截异常就完成了,这里只是拦截DAO层的异常,此方法的好处就是处理异常和功能实现完全分离开,只需要在写方法的时候要记得抛出相应的异常,当出现异常时ThrowsAdvice就会拦截到该异常,并获取该异常的详细信息。
这里贴出我测试可以使用的配置:
<bean id="exceptionLog" class="net.chinanets.utils.AopExceptionHandler"></bean>
<!-- beanName自动代理 -->
<bean id="logAdvice"
class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
<property name="beanNames">
<list>
<value>*Service</value>
</list>
</property>
<property name="interceptorNames">
<list>
<value>exceptionLog</value>
</list>
</property>
</bean>
注:
<property name="beanNames">
<list>
<value>*Service</value>
</list>
</property>
<value>*Service</value>可以拦截所有的service
*Service匹配你beans.xml中配置的所有bean的ID
这里的切入点是匹配beans ID比较简便,如果从文件路径切入可能会各种报错。
- spring AOP的异常拦截
- spring AOP的异常拦截
- spring AOP的异常拦截
- spring AOP的异常拦截
- spring AOP的异常拦截
- Spring AOP 异常拦截器
- 使用spring aop拦截异常
- Spring aop 实现异常拦截
- Spring aop 实现异常拦截
- 详解Spring Aop 拦截 Struts2 Action 出现的异常
- 通过spring的aop统一拦截Exception抛出自定义异常
- spring的aop拦截器
- spring的aop拦截action中的方法会报java.lang.NoSuchMethodException: $Proxy97.test()异常
- Spring的AOP子调用拦截问题
- Spring AOP 日志拦截器的事务管理
- Spring AOP拦截器的相关配置
- spring security基于aop的方法拦截
- 使用spring的aop进行权限拦截
- 翻译2
- Ubuntu下安装JDK1.6
- eclipse 使用JDepend 进行依赖项检查
- JDBC存储过程的调用
- Ubuntu中Nginx的安装与配置
- spring AOP的异常拦截
- Java实现O(n)最大连续子序列和
- HDU5011 Game(Nim博弈)
- 《Android编程权威指南》关于UI fragment和fragment管理器的总结
- android----如何图像处理中的内存问题(Out of memory)?
- 北京要去的地方
- iOS 绘制直线、矩形、文字的方式
- 实现新浪微博@@@
- owasp appsec 2014 usa online video