课程链接:

1    解析

1.1  类的方式实现各种通知需要实现的接口

1.2  创建Spring aop代理的优点及方法

1.3  代理控制切入点和通知的顺序的代码实现(具体完全实现,见代码2.1)

1.4  代理方式选择

2    代码演练

2.1  类的方式实现各种通知

2.2  类的方式实现各种通知(和2.1对比)

1    解析

1.1  类的方式实现各种通知需要实现的接口

前置通知:MethodBeforeAdvice

后置通知:AfterReturningAdvice

异常通知:ThrowsAdvice

环绕通知:MethodInterceptor

1.2  创建Spring aop代理的优点及方法

优点:可以完全控制切入点和通知(advice)以及他们的顺序

方法:基本方法是使用org.springframework.aop.framework.ProxyFactoryBean

1.3  代理控制切入点和通知的顺序的代码实现(具体完全实现,见代码2.1)

<!-- 从这里开始,引入多个通知   --><!-- 引入的业务类不是ProxyFactoryBean ,而是getObject返回的,即 target==》bizLogicImplTarget -->

<bean id="bizLogicImpl" class="org.springframework.aop.framework.ProxyFactoryBean">

<!--     具体业务类 -->

    <property name="target">

        <ref bean="bizLogicImplTarget"/>

    </property>

    <!--     list通知不是按照顺序执行的,而是按照通知的先后顺序执行的,先执行前置通知,然后执行环绕通知,最后执行后置通知 -->

    <property name="interceptorNames">

        <list>

            <value>defaultAdvisor</value>

<value>moocAfterReturningAdvice</value> <value>moocMethodInterceptor</value> <value>moocThrowsAdvice</value> </list> </property> </bean>
<!--     使用前置通知,切入点为pointcutBean -->
<bean id="defaultAdvisor" class="org.springframework.aop.support.DefaultPointcutAdvisor">

    <property name="advice" ref="moocBeforeAdvice"></property>

    <property name="pointcut" ref="pointcutBean"></property>

</bean>
 

1.4  代理方式选择

1.4.1  使用ProxyFactoryBean或者其它loC相关类来创建AOP代理的最重要好处是通知和切入点也可以由loC来管理

1.4.2  被代理类没有实现任何接口,使用CGLIB代理,否则JDK代理

1.4.3  通过设置proxyTargetClass为true,可强制使用CGLIB

1.4.4  如果目标类实现了一个(或者多个)接口,那么创建代理的类型将依赖ProxyFactoryBean的配置

1.4.5  如果ProxyFactoryBean的proxyInterfaces属性被设置为一个或者多个全限定接口名,基于JDK的代理将被创建b

1.4.6  如果ProxyFactoryBean的proxyInterfaces属性没有被设置,但是目标类实现了一个(或者更多)接口,那么ProxyFactoryBean将自动检测到这个目标类已经实现了至少一个接口,创建一个基于JDK的代理。

2    代码演练

2.1  类的方式实现各种通知

测试类:

package com.imooc.test.aop;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.BlockJUnit4ClassRunner; import com.imooc.aop.api.BizLogic;
import com.imooc.test.base.UnitTestBase; @RunWith(BlockJUnit4ClassRunner.class)
public class TestAOPAPI extends UnitTestBase{ public TestAOPAPI() {
super("classpath:spring-aop-api.xml");
// TODO Auto-generated constructor stub
} @Test
public void testSave(){
BizLogic bLogic = super.getbean("bizLogicImpl"
);
bLogic.save();
}
}

配置文件:(可以细细看这篇详细内容)

<?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:aop="http://www.springframework.org/schema/aop"
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/aop
http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
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"
> <bean id="moocBeforeAdvice" class="com.imooc.aop.api.MoocBeforeAdvice"></bean> <bean id="moocAfterReturningAdvice" class="com.imooc.aop.api.MoocAfterReturningAdvice"></bean> <bean id="moocMethodInterceptor" class="com.imooc.aop.api.MoocMethodInterceptor"></bean> <bean id="moocThrowsAdvice" class="com.imooc.aop.api.MoocThrowsAdvice"></bean> <bean id="bizLogicImplTarget" class="com.imooc.aop.api.BizLogicImpl"></bean>

<!--  执行所有sa打头的方法,都会引入切面 --><!-- 实现之一:NameMatchMethodPointcut,根据方法名字进行匹配 ,自带方法 -->

<!-- 更加灵活的配置切入点 -->

 <bean id="pointcutBean" class="org.springframework.aop.support.NameMatchMethodPointcut">

    <property name="mappedNames">

        <list>

            <value>sa*</value>

        </list>

    </property>

</bean>

<bean id="defaultAdvisor" class="org.springframework.aop.support.DefaultPointcutAdvisor">

    <property name="advice" ref="moocBeforeAdvice"></property>

    <property name="pointcut" ref="pointcutBean"></property>

</bean>

<!-- 从这里开始,引入多个通知   --><!-- 引入的业务类不是ProxyFactoryBean ,而是getObject返回的,即 target==》bizLogicImplTarget -->

<bean id="bizLogicImpl" class="org.springframework.aop.framework.ProxyFactoryBean">

<!--     具体业务类 -->

    <property name="target">

        <ref bean="bizLogicImplTarget"/>

    </property>

    <!--     list通知不是按照顺序执行的,而是按照通知的先后顺序执行的,先执行前置通知,然后执行环绕通知,最后执行后置通知 -->

    <property name="interceptorNames">

        <list>

            <value>defaultAdvisor</value>

            <value>moocAfterReturningAdvice</value>

            <value>moocMethodInterceptor</value>

            <value>moocThrowsAdvice</value>

        </list>

    </property>

</bean>

</beans>

实体类:

package com.imooc.aop.api;

public class BizLogicImpl implements BizLogic{

    @Override
public String save() {
System.out.println("syso save");
return "BizLogicImpl save";
} }

接口类:

package com.imooc.aop.api;

public interface BizLogic {
String save();
}

前置通知:

package com.imooc.aop.api;

import java.lang.reflect.Method;

import org.springframework.aop.MethodBeforeAdvice;

public class MoocBeforeAdvice implements MethodBeforeAdvice{

    /**
* 实现MethodBeforeAdvice接口,可以在连接点之前执行
*
*
* 作用是什么?
* 将前一章中的xml配置方式改为了实现接口的实现方式 具体细节和使用参考开发文档
*
*/
@Override
public void before(Method method, Object[] aobj, Object obj)
throws Throwable {
System.out.println("MoocBeforeAdvice:"+method.getName()+" "+
obj.getClass().getName());
} }

后置通知:

package com.imooc.aop.api;

import java.lang.reflect.Method;

import org.springframework.aop.AfterReturningAdvice;

/**
* 实现AfterReturningAdvice接口,可以在连接点之后执行
* @author weijingli
*
*/
public class MoocAfterReturningAdvice implements AfterReturningAdvice{ /**
* obj 作为输出
*/
@Override
public void afterReturning(Object obj, Method method, Object[] aobj,
Object obj1) throws Throwable {
System.out.println("MoocAfterReturningAdvice:"+method.getName()+
" 类的名称:"+obj1.getClass().getName()+" "+obj);
} }

环绕通知:

package com.imooc.aop.api;

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation; /**
* 引入环绕通知
*
* 实现 MethodInterceptor 接口
* @author weijingli
*
*/
public class MoocMethodInterceptor implements MethodInterceptor{ @Override
public Object invoke(MethodInvocation methodinvocation) throws Throwable { //实现前置通知的方法
//得到方法 得到类
System.out.println("MoocMethodInterceptor1:"+methodinvocation.getMethod().getName()+" "
+methodinvocation.getStaticPart().getClass().getName()); Object obj = methodinvocation.proceed(); //实现后置通知方法
System.out.println("MoocMethodInterceptor2:"+obj); return obj;
} }

异常通知:

package com.imooc.aop.api;

import java.lang.reflect.Method;

import org.springframework.aop.ThrowsAdvice;

/**
* 引入spring aop jar包 ,实现 ThrowsAdvice 接口
* 实现异常通知
*
* 可以一参,可以多参
* @author weijingli
*
*/
public class MoocThrowsAdvice implements ThrowsAdvice{
public void afterThrowing(Method method,Object[] args,Object target,Exception ex) throws Throwable{
System.out.println("MoocThrowAdvice afterThrowiing2:"+method.getName()+" "
+target.getClass().getName());
}
}

打印日志:

四月 21, 2019 6:16:29 下午 org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@5abce07: startup date [Sun Apr 21 18:16:28 CST 2019]; root of context hierarchy
四月 21, 2019 6:16:29 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [spring-aop-api.xml]
MoocBeforeAdvice:save com.imooc.aop.api.BizLogicImpl
MoocMethodInterceptor1:save java.lang.reflect.Method

四月 21, 2019 6:16:30 下午 org.springframework.context.support.ClassPathXmlApplicationContext doClose
信息: Closing org.springframework.context.support.ClassPathXmlApplicationContext@5abce07: startup date [Sun Apr 21 18:16:28 CST 2019]; root of context hierarchy
syso save
MoocMethodInterceptor2:BizLogicImpl save
MoocAfterReturningAdvice:save 类的名称:com.imooc.aop.api.BizLogicImpl BizLogicImpl save

2.2  类的方式实现各种通知(和2.1对比)sa方法不执行

测试类:

package com.imooc.test.aop;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.BlockJUnit4ClassRunner; import com.imooc.aop.api.BizLogic;
import com.imooc.test.base.UnitTestBase; @RunWith(BlockJUnit4ClassRunner.class)
public class TestAOPAPI extends UnitTestBase{ public TestAOPAPI() {
super("classpath:spring-aop-api.xml");
// TODO Auto-generated constructor stub
} @Test
public void testSave(){
BizLogic bLogic = super.getbean("bizLogicImpl");
bLogic.sove();
} }

实现类:

package com.imooc.aop.api;

public class BizLogicImpl implements BizLogic{

    @Override
public String sove() {
System.out.println("syso save");
return "BizLogicImpl save";
}
}

接口类:

package com.imooc.aop.api;

public interface BizLogic {
String sove();
}

打印日志:

四月 22, 2019 9:49:02 下午 org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@7fe219e7: startup date [Mon Apr 22 21:49:02 CST 2019]; root of context hierarchy
四月 22, 2019 9:49:03 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [spring-aop-api.xml]
MoocMethodInterceptor1:sove java.lang.reflect.Method
四月 22, 2019 9:49:05 下午 org.springframework.context.support.ClassPathXmlApplicationContext doClose
信息: Closing org.springframework.context.support.ClassPathXmlApplicationContext@7fe219e7: startup date [Mon Apr 22 21:49:02 CST 2019]; root of context hierarchy
syso save
MoocMethodInterceptor2:BizLogicImpl save
MoocAfterReturningAdvice:sove 类的名称:com.imooc.aop.api.BizLogicImpl BizLogicImpl save

Spring课程 Spring入门篇 6-2 ProxyFactoryBean及相关内容(上)的更多相关文章

  1. Spring Boot -01- 快速入门篇(图文教程)

    Spring Boot -01- 快速入门篇(图文教程) 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到[慕课网]手机 app ...

  2. Spring实践系列-入门篇(一)

    本文主要介绍了在本地搭建并运行一个Spring应用,演示了Spring依赖注入的特性 1 环境搭建 1.1 Maven依赖 目前只用到依赖注入的功能,故以下三个包已满足使用. <properti ...

  3. Spring课程 Spring入门篇 2-1 IOC和bean容器

    课程链接: 本节讲了5部分内容,6为项目demo: 1 接口及面向接口编程 2 什么是IOC 3 Spring的bean配置 4 Bean的初始化 5 Demo 自己理解: 1 高层模块和底层模块都依 ...

  4. Spring课程 Spring入门篇 3-3 Spring bean装配(上)之aware接口

    课程链接: 本节主要介绍了以下内容: 1 aware介绍 2 代码演练 3 课程总结 1 aware介绍 1.1 为什么要使用aware? 在java类中,可以方便的获取xml配置文件中的bean的各 ...

  5. Spring课程 Spring入门篇 6-3 ProxyFactoryBean及相关内容(下)

    1 解析 1.1 使用global advisors demo 1.2 jdk代理和cglib代理的选择 1.3 如何强制使用CGLIB实现AOP? 1.4 JDK动态代理和CGLIB字节码生成的区别 ...

  6. Spring课程 Spring入门篇 7-2 Advice定义及实例

    1 解析 1.1 通知:after和afterreturning的区别 1.2 @RunWith 是什么? 2 代码演练 2.1 注解方式配置通知的两种方式 2.2 异常通知 2.3 非异常通知 1 ...

  7. Spring课程 Spring入门篇 5-2 配置切面aspect

    本节主要讲了在xml中配置切面的demo 1 解析 1.1 配置切面xml 1.2 配置切面xml 1.3 问:什么是动态代理? 2 代码演练 2.1 配置切面xml 1 解析 1.1 配置切面xml ...

  8. Spring课程 Spring入门篇 4-9 Spring bean装配之对jsr支持的说明

    1 解析 1.1 疑问:2.2去掉@resource注解,为什么不能赋值?不是有set方法了吗? 1.2 @resource注解版本支持 1.3 没有显式指定@resource的那么,默认名称从何获得 ...

  9. Spring课程 Spring入门篇 4-8 Spring bean装配之基于java的容器注解说明--基于泛型的自动装配

    1 解析 1.1 什么是泛型? 1.2 泛型有什么作用? 1.3 泛型装配样式? 2 代码演练 2.1 泛型应用 1 解析 1.1 什么是泛型? Java泛型设计原则:只要在编译时期没有出现警告,那么 ...

随机推荐

  1. java字段中初始化的规律与如何用静态成员函数调用非静态成员

    java字段中初始化的规律: 执行以下代码,出现的结果是什么? class InitializeBlockClass{ { field=200; } public int field=100; pub ...

  2. C#-★结构体★

    结构体: 结构体类型是用户自己定义的一种类型,它是由其他类型组合而成的,可包含构造函数.常数.字段.方法.属性.索引器.运算符.事件和嵌套类型的值类型. 结构体在几个方面不同于类:结构体为值类型而不是 ...

  3. C#集合之栈

    栈(Stack)和队列是非常类似的一个容器,只是栈是一个后进先出(LIFO)的容器. 栈用Push()方法在栈中添加元素,用Pop()方法获取最近添加的一个元素: Stack<T>与Que ...

  4. 剑指offer——面试题17:打印从1到最大的n位数

    用字符串模拟加法: #include"iostream" #include"string.h" using namespace std; bool AddOne ...

  5. Java - 二分法查找(尚学堂第七章数组)

    import java.util.Arrays; public class TestBinarySearch { public static void main(String[] args) { in ...

  6. C# GridView 导出Excel表

    出错1:类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内解决方案:在后台文件中重载VerifyRenderingInServerForm方法,如 ...

  7. Docker安装及常用操作

    Docker简介: Docker是一个轻量级容器技术,类似于虚拟机技术,但性能远远高于虚拟机,Docker支持将软件编译成一个镜像(image),在这个镜像中做好对软件的各种配置,然后可以运行这个镜像 ...

  8. spring项目中aop的使用

    AOP:是一种面向切面的编程范式,是一种编程思想,旨在通过分离横切关注点,提高模块化,可以跨越对象关注点.Aop的典型应用即spring的事务机制,日志记录.利用AOP可以对业务逻辑的各个部分进行隔离 ...

  9. MySQL约束和修改数据表知识集结

    一.约束 划分标准:功能.数据列的数目 功能: (1)NOT NULL(非空约束) (2)PRIMARY KEY(主键约束) (3)UNIQUE(唯一约束) (4)DEFAULT(默认约束) (5)F ...

  10. 【Css】Layout布局(二)

    css定位(Positioning) 所谓定位,即允许你定义元素框相对于其正常位置应该出现的位置,或者相对于父元素.另一个元素甚至浏览器窗口本身的位置. css提供了三种基本的定位机制:普通流.浮动和 ...