(残梦追月原创,转载请注明)
本文地址:http://www.blogjava.net/cmzy/archive/2008/08/17/222624.html
我们一直使用ProxyFactoryBean来显式的创建AOP代理。但是在很多场合,这种方式将会使编写配置文件的工作量大大增加;由于要从
ProxyFactoryBean获得代理对象,也会使应用和Spring之间的耦合度增加。下面介绍使用Spring提供的自动代理机制来解决这类问
题。
1、使用
BeanNameAutoProxyCreator
Spring提供的BeanNameAutoProxyCreator类允许我们通过Bean的name属性来指定代理的Bean。它暴露了
java.lang.String[]类型的beanNames和
interceptorNames属性。beanNames可以指定被代理的Bean名字列表,支持“*”通配符,例如“*DAO”表示所有名字以
“DAO”结尾的Bean。interceptorNames指定通知(Advice)列表,或者通知者(Advisor)列表。
下面通过一个例程来演示如何使用BeanNameAutoProxyCreator。在例子中,有两个Bean:TestBeanA和BeanB,并在
TestMain类中的main方法中调用其MyMethod()方法。自动代理将会在方法调用前自动的执行配置的前置通知,输出提示信息。
新建一个名字为AOP_Test4.10的工程,添加Spring的IoC和AOP库后,新建一aop.test包,再分别创建两个类TestBeanA和BeanB,添加MyMethod()方法,代码如下:
-
-
-
-
package
aop.test;
-
-
-
-
-
public
class
TestBeanA {
-
public
void
MyMethod() {
-
System.out.println(this
.getClass().getName()
-
+ ".MyMethod() is run!"
);
-
}
-
}
-
-
-
-
package
aop.test;
-
-
-
-
-
public
class
BeanB {
-
public
void
MyMethod() {
-
System.out.println(this
.getClass().getName()
-
+ ".MyMethod() is run!"
);
-
}
-
}
再创建前置通知类BeforeAdvice:
-
-
-
-
package
aop.test;
-
import
java.lang.reflect.Method;
-
import
org.springframework.aop.MethodBeforeAdvice;
-
-
-
-
-
public
class
BeforeAdvice
implements
MethodBeforeAdvice {
-
public
void
before(Method method, Object[] args, Object target)
-
throws
Throwable {
-
System.out.println(method.getName() + "(),将要运行!"
);
-
}
-
}
最后创建含有main方法的测试类TestMain:
-
-
-
-
package
aop.test;
-
-
import
org.springframework.context.ApplicationContext;
-
import
org.springframework.context.support.ClassPathXmlApplicationContext;
-
-
-
-
-
public
class
TestMain {
-
public
static
void
main(String[] args) {
-
ApplicationContext ac = new
ClassPathXmlApplicationContext(
-
"applicationContext.xml"
);
-
TestBeanA beanA = (TestBeanA)ac.getBean("TestBeanA"
);
-
beanA.MyMethod();
-
BeanB beanB = (BeanB)ac.getBean("BeanB"
);
-
beanB.MyMethod();
-
}
-
}
在配置文件中配置Bean和自动代理Bean,完成后代码如下:
-
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
-
<
beans
…………
>
-
<
bean
id
=
"TestBeanA"
class
=
"aop.test.TestBeanA"
/>
-
<
bean
id
=
"BeanB"
class
=
"aop.test.BeanB"
/>
-
<
bean
id
=
"BeforeAdvice"
class
=
"aop.test.BeforeAdvice"
>
</
bean
>
-
-
<
bean
class
="org.springframework.aop.framework.autoproxy.
-
BeanNameAutoProxyCreator">
-
<
property
name
=
"beanNames"
>
-
<
list
>
-
<
value
>
Test*
</
value
>
-
</
list
>
-
</
property
>
-
<
property
name
=
"interceptorNames"
>
-
<
list
>
-
<
value
>
BeforeAdvice
</
value
>
-
</
list
>
-
</
property
>
-
</
bean
>
-
</
beans
>
运行主类,输出结果如下:
可以看到,在主类TestMain中,我们是直接从Spring
IoC容器中获取收管Bean而不是像以前那样从ProxyFactoryBean中获取代理,但是我们的前置通知BeforeAdvice仍然在
TestBeanA对象的MyMethod()方法执行前被触发,这说明我们的自动代理正在工作。
2、使用
DefaultAdvisorAutoProxyCreator
DefaultAdvisorAutoProxyCreator允许我们只需定义相应的Advisor通知者,就可以完成自动代理。配
置好DefaultAdvisorAutoProxyCreator受管Bean后,它会自动查找配置文件中定义的Advisor,并将它们作用于所有的
Bean。
修改例程4.10的配置文件,使用DefaultAdvisorAutoProxyCreator来完成自动代理。完成后配置文件代码如下(本例完整工程代码见例程4.11):
-
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
-
<
beans
……
>
-
<
bean
id
=
"TestBeanA"
class
=
"aop.test.TestBeanA"
/>
-
<
bean
id
=
"BeanB"
class
=
"aop.test.BeanB"
/>
-
<
bean
id
=
"BeforeAdvice"
class
=
"aop.test.BeforeAdvice"
/>
-
<
bean
class
="org.springframework.aop.framework.autoproxy.
-
DefaultAdvisorAutoProxyCreator" />
-
-
<
bean
class
="org.springframework.aop.support.NameMatchMethod
-
PointcutAdvisor">
-
<
property
name
=
"advice"
ref
=
"BeforeAdvice"
/>
-
<
property
name
=
"mappedNames"
>
-
<
list
>
-
<
value
>
*Method*
</
value
>
-
</
list
>
-
</
property
>
-
</
bean
>
-
</
beans
>
运行主类输出结果如下:
By:残梦追月
分享到:
相关推荐
Spring的代理机制是其核心特性之一,特别是在AOP(面向切面编程)中扮演着重要角色。AOP允许程序员在不修改源代码的情况下,通过在特定的“连接点”(如方法调用)插入额外的功能,例如日志、事务管理等。Spring提供...
Spring框架提供了两种动态代理机制:JDK动态代理和CGLIB代理,它们分别基于这两种技术。 1. JDK动态代理: - 当被代理的目标对象实现了至少一个接口时,Spring会选择使用JDK动态代理。它通过反射机制生成一个实现...
总结来说,“spring proxy代理模仿”项目是对Spring AOP代理机制的实践与理解,通过此项目,你可以深入学习到如何在不修改原有业务代码的基础上,利用Spring的动态代理能力添加额外的功能,提升代码的可维护性和复用...
下面将详细介绍这两种动态代理机制。 1. JDK动态代理: JDK动态代理基于Java的接口实现。如果我们的目标对象实现了至少一个接口,那么Spring会为我们创建一个代理类,该类实现了相同的接口,并在调用接口方法时...
**Spring AOP 实现机制详解** Spring AOP(面向切面编程)是Spring框架的核心特性之一,它允许程序员在不修改源代码的情况下,通过“切面”来插入额外的业务逻辑,如日志、事务管理等。AOP的引入极大地提高了代码的...
然而,如果需要更精细的控制,可以通过`@EnableAspectJAutoProxy`注解开启基于AspectJ的自动代理支持,或者通过`proxyTargetClass`属性来强制使用CGLIB代理。 总结一下,Spring的AOP机制通过JDK动态代理和CGLIB动态...
DI允许我们声明Bean的依赖,而Spring会自动管理这些依赖的生命周期和装配。 ApplicationContext是Bean工厂的高级形式,提供了更多的企业级功能,如消息资源处理、国际化支持以及AOP代理。通过ApplicationContext,...
总结来说,Spring AOP中的JDK动态代理机制是一种高效且灵活的实现方式,它允许我们在不修改原始代码的前提下,通过代理对象添加额外的功能。这使得我们能够更专注于业务逻辑,而不是关注点的实现。通过理解和掌握这...
综上所述,这个压缩包包含了一系列Spring框架的专题学习资料,涵盖了从基础到高级的多个方面,特别是代理机制(静态和动态)、AOP和自动装配,对于理解和使用Spring进行高效开发大有裨益。通过深入学习这些材料,...
在Spring框架中,虽然动态代理(如JDK动态代理或CGLIB代理)更常见,因为它们可以自动创建代理对象,但静态代理也有其应用场景,特别是当需要在不依赖Spring的情况下,或者对性能有较高要求时。 要实现Spring框架下...
本篇文章将深入探讨Spring中的动态代理机制,以及它是如何工作的。 1. **什么是动态代理?** 动态代理是指在程序运行时动态地创建一个类的实例,这个实例能够代理另一个对象的方法调用。在Java中,可以使用`java....
Nepxion Matrix是一种集成的Spring AutoProxy,Spring Registrar和Spring Import Selector三种机制的AOP框架,具有很高的通用性,健壮性,可选和易用性请联系我微信,钉钉,公众号和文档简介Spring自动代理机制它...
总结来说,Spring AOP利用代理模式实现了面向切面编程,通过动态代理机制可以在不修改目标对象代码的情况下,对方法调用进行拦截并添加额外的功能。无论是JDK动态代理还是CGLIB代理,都能有效地支持这一功能,使得...
在Spring框架中,自动代理是一种方便的特性,它允许我们无需手动创建代理对象即可为我们的bean添加拦截器或顾问(advisors)。`DefaultAdvisorAutoProxyCreator`是Spring AOP中用于实现自动代理创建的核心类,它根据...
首先,JDK代理,也称为接口代理,是Java内置的一种动态代理机制。通过实现`java.lang.reflect.InvocationHandler`接口并调用`java.lang.reflect.Proxy`类的静态方法`newProxyInstance()`,我们可以创建一个代理对象...
Spring框架是Java开发中广泛使用的轻量级框架,它也提供了强大的代理机制,包括静态代理和动态代理。下面我们将深入探讨这两个概念以及Spring如何实现代理。 1. 静态代理: 静态代理是在编译时就已经明确知道代理...
理解 Spring 事务管理的核心在于其代理机制和事务传播行为。代理机制决定了何时以及如何应用事务规则,而事务传播行为定义了在一个事务中的方法被另一个事务中的方法调用时,应该如何处理事务。例如,PROPAGATION_...
在这个例子中,我们将聚焦于Spring的声明式事务管理,特别是通过`TransactionProxyFactoryBean`代理机制以及`@Transactional`注解与AOP(面向切面编程)的结合使用。 首先,`TransactionProxyFactoryBean`是Spring...
Spring AOP通过代理模式实现,可以在不修改源代码的情况下,向已有方法添加额外的功能。这里有三个与AOP相关的术语: 1. **AOP Before**:前置通知,是指在目标方法被调用之前执行的增强代码。在Spring中,我们可以...
动态代理提供了创建代理对象的机制,而Spring AOP则是基于动态代理实现的面向切面编程框架,简化了在多处插入相同逻辑的复杂度。在实际开发中,理解并熟练运用这两个技术对于提高代码质量和可维护性至关重要。