首页 > 代码库 > spring-AspectJ异常通知

spring-AspectJ异常通知

一、创建项目
    项目名称:spring101002
二、添加jar包
    1.在项目中创建lib目录
        /lib
    2.在lib目录下添加相关spring jar包
        --用于AspectJ
        com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar
        spring-aspects-3.2.0.RELEASE.jar
        --用于切面编程
        com.springsource.org.aopalliance-1.0.0.jar
        commons-logging.jar
        junit-4.10.jar
        log4j.jar
        --用于切面编程
        spring-aop-3.2.0.RELEASE.jar
        spring-beans-3.2.0.RELEASE.jar
        spring-context-3.2.0.RELEASE.jar
        spring-core-3.2.0.RELEASE.jar
        spring-expression-3.2.0.RELEASE.jar
三、添加配置文件
    1.在项目中创建conf目录
        /conf
    2.在conf目录下添加配置文件
        配置文件名称:applicationContext.xml
        配置文件内容:
        <?xml version="1.0" encoding="UTF-8"?>
        <beans xmlns="http://www.springframework.org/schema/beans"
               xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
               xmlns:context="http://www.springframework.org/schema/context"
               xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
        </beans>
四、创建业务bean
    1.在src目录下创建业务bean包
        包名:cn.jbit.spring101002.service
    2.在包下创建业务bean
        业务bean名称:UserService.java
        业务bean内容:
        /**
         * 被代理类
         * @author Administrator
         *
         */
        public class UserService {
            /**
             * 6.修改用户
             */
            public void update(){
                System.out.println("执行修改用户方法");
                int a = 1/0;
            }
        }
五.创建切面
    1)在src下创建包
        包名:cn.jbit.spring101002.aspect
    2)在包下创建自定义切面类
        切面名称:AnnotationAspect.java
        切面内容:
        /**
         * 自定义切面
         * @author Administrator
         *
         */
        @Aspect
        public class AnnotationAspect {
            /**
             * 6.异常通知
             */
            @AfterThrowing(value="http://www.mamicode.com/execution(* cn.jbit.spring101002.service.UserService.*(..))",throwing="throwable")
            public void exception(JoinPoint joinPoint,Throwable throwable){
                System.out.println("异常通知被执行,执行连接点:"+joinPoint+",产生异常"+throwable);
            }
        }
六、在核心配置文件中添加配置信息
    <!-- 配置被代理类 -->
    <bean id="userservice" class="cn.jbit.spring101002.service.UserService"></bean>
    
    <!-- 配置切面 -->
    <bean id="annotationaspect" class="cn.jbit.spring101002.aspect.AnnotationAspect"></bean>
    
    <!-- 配置自动代理  -->
    <aop:aspectj-autoproxy/>
七、测试
    1.在项目中创建test目录
        /test
    2.在test目录中创建测试包
        包名:cn.jbit.spring101002.aspect
    3.在测试包中创建测试类
        测试类名:AnnotationAspectTest.java
        测试内容:
        /**
         * 测试类
         * @author Administrator
         *
         */
        public class AnnotationAspectTest {
            /**
             * 6.测试异常通知
             */
            @Test
            public void testAfterThrowing(){
                //读取并加载配置文件
                ApplicationContext context = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
                //根据bean id 获取bean对象
                UserService userService = (UserService) context.getBean("userservice");
                //调用保存用户方法
                userService.update();
            }
        }

本文出自 “素颜” 博客,请务必保留此出处http://suyanzhu.blog.51cto.com/8050189/1562140

spring-AspectJ异常通知