• 注解方式实现AOP编程


    步骤:

    1) 先引入aop相关jar文件           (aspectj  aop优秀组件)                                      

             spring-aop-3.2.5.RELEASE.jar   【spring3.2源码】

    aopalliance.jar                                        【spring2.5源码/lib/aopalliance】

    aspectjweaver.jar                        【spring2.5源码/lib/aspectj】或【aspectj-1.8.2lib】

    aspectjrt.jar                                   【spring2.5源码/lib/aspectj】或【aspectj-1.8.2lib】

    注意: 用到spring2.5版本的jar文件,如果用jdk1.7可能会有问题。

                       需要升级aspectj组件,即使用aspectj-1.8.2版本中提供jar文件提供。

    2) bean.xml中引入aop名称空间

    3) 开启aop注解

    4) 使用注解

    @Aspect                            指定一个类为切面类        
    @Pointcut("execution(* cn.loaderman.e_aop_anno.*.*(..))")  指定切入点表达式
    
    @Before("pointCut_()")                前置通知: 目标方法之前执行
    @After("pointCut_()")                    后置通知:目标方法之后执行(始终执行)
    @AfterReturning("pointCut_()")            返回后通知: 执行方法结束前执行(异常不执行)
    @AfterThrowing("pointCut_()")            异常通知:  出现异常时候执行
    @Around("pointCut_()")                环绕通知: 环绕目标方法执行

    package loaderman.e_aop_anno;
    
    import org.aspectj.lang.ProceedingJoinPoint;
    import org.aspectj.lang.annotation.After;
    import org.aspectj.lang.annotation.AfterReturning;
    import org.aspectj.lang.annotation.AfterThrowing;
    import org.aspectj.lang.annotation.Around;
    import org.aspectj.lang.annotation.Aspect;
    import org.aspectj.lang.annotation.Before;
    import org.aspectj.lang.annotation.Pointcut;
    import org.springframework.stereotype.Component;
    
    
    @Component
    @Aspect  // 指定当前类为切面类
    public class Aop {
    
        // 指定切入点表单式: 拦截哪些方法; 即为哪些类生成代理对象
    
        @Pointcut("execution(* cn.loaderman.e_aop_anno.*.*(..))")
        public void pointCut_(){
        }
    
        // 前置通知 : 在执行目标方法之前执行
        @Before("pointCut_()")
        public void begin(){
            System.out.println("开始事务/异常");
        }
    
        // 后置/最终通知:在执行目标方法之后执行  【无论是否出现异常最终都会执行】
        @After("pointCut_()")
        public void after(){
            System.out.println("提交事务/关闭");
        }
    
        // 返回后通知: 在调用目标方法结束后执行 【出现异常不执行】
        @AfterReturning("pointCut_()")
        public void afterReturning() {
            System.out.println("afterReturning()");
        }
    
        // 异常通知: 当目标方法执行异常时候执行此关注点代码
        @AfterThrowing("pointCut_()")
        public void afterThrowing(){
            System.out.println("afterThrowing()");
        }
    
        // 环绕通知:环绕目标方式执行
        @Around("pointCut_()")
        public void around(ProceedingJoinPoint pjp) throws Throwable{
            System.out.println("环绕前....");
            pjp.proceed();  // 执行目标方法
            System.out.println("环绕后....");
        }
    
    }
    package loaderman.e_aop_anno;
    
    import org.junit.Test;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class App {
    
        ApplicationContext ac =
                new ClassPathXmlApplicationContext("cn/loaderman/e_aop_anno/bean.xml");
    
        // 目标对象有实现接口,spring会自动选择“JDK代理”
        @Test
        public void testApp() {
            IUserDao userDao = (IUserDao) ac.getBean("userDao");
            System.out.println(userDao.getClass());//$Proxy001
            userDao.save();
        }
    
        // 目标对象没有实现接口, spring会用“cglib代理”
        @Test
        public void testCglib() {
            OrderDao orderDao = (OrderDao) ac.getBean("orderDao");
            System.out.println(orderDao.getClass());
            orderDao.save();
        }
    
        @Deprecated
        // 共性问题:如果目标对象有实现接口,在从容器中获取目标对象的时候,只能通过接口接收对象。
        public void testApp2() {
            // 错误代码: 只能用接口接收
            UserDao userDao = (UserDao) ac.getBean("userDao");
            System.out.println(userDao.getClass());//$Proxy001
            userDao.save();
        }
    
    
        @Test
        public void testGetObj() throws Exception {
            OrderDao orderDao1 = (OrderDao) ac.getBean("orderDao");
            OrderDao orderDao2 = (OrderDao) ac.getBean("orderDao");
    
            System.out.println(orderDao1);
            System.out.println(orderDao2);
    
        }
    }
    package loaderman.e_aop_anno;
    
    
    public interface IUserDao {
        void save();
    }
    package loaderman.e_aop_anno;
    
    import org.springframework.context.annotation.Scope;
    import org.springframework.stereotype.Component;
    
    /**
     * 目标对象
     *
     */
    @Component   // 加入容器
    @Scope("prototype")
    public class OrderDao{
    
        public void save() {
            System.out.println("-----核心业务:保存!!!------");
        }
    }
    package loaderman.e_aop_anno;
    
    import org.springframework.stereotype.Component;
    
    /**
     * 目标对象
     *
     */
    @Component   // 加入容器
    public class UserDao implements IUserDao{
    
        @Override
        public void save() {
            System.out.println("-----核心业务:保存!!!------");
        }
    }
    <?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:p="http://www.springframework.org/schema/p"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:aop="http://www.springframework.org/schema/aop"
        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
            http://www.springframework.org/schema/aop
            http://www.springframework.org/schema/aop/spring-aop.xsd">
        
        <!-- 开启注解扫描 -->
        <context:component-scan base-package="loaderman.e_aop_anno"></context:component-scan>
        
        <!-- 开启aop注解方式 -->
        <aop:aspectj-autoproxy></aop:aspectj-autoproxy>
    </beans>      
      
  • 相关阅读:
    关于放入cookie中的中文取出后变乱码的问题及解决办法!
    用灌了google的颜色搜索,可以看看这个。
    趁准备换个工作的工夫,去天津走了一圈.
    python的面向对象学习分享
    Http Handler 介绍
    大型网站系统架构分析
    Http 请求处理流程
    uniapp nfc读写
    安卓的颜色透明度和html的不一样
    uniapp App上传文件
  • 原文地址:https://www.cnblogs.com/loaderman/p/10042827.html
Copyright © 2020-2023  润新知