="1.0" encoding="UTF-8"
?>
<
beans
xmlns
="http://www.springframework.org/schema/beans"
xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation
="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd"
>
<
bean
id
="beforeAdvice"
class
="spring.chapter3.advice.AdviceBeforeComponent"
/>
<
bean
id
="component"
class
="spring.chapter3.proxy.Component"
/>
<
bean
id
="pointcutBean"
class
="org.springframework.aop.support.NameMatchMethodPointcut"
>
<
property
name
="mappedNames"
>
<
list
>
<
value
>
business*
</
value
>
</
list
>
</
property
>
</
bean
>
<
bean
id
="defaultAdvisor"
class
="org.springframework.aop.support.DefaultPointcutAdvisor"
>
<
property
name
="advice"
ref
=" beforeAdvice "
/>
<
property
name
="pointcut"
ref
="pointcutBean"
/>
</
bean
>
<
bean
id
="proxy"
class
="org.springframework.aop.framework.ProxyFactoryBean"
>
<
property
name
="proxyInterfaces"
value
="spring.chapter3.proxy.IComponent"
/>
<
property
name
="target"
ref
="component"
/>
<
property
name
="interceptorNames"
>
<
list
>
<
value
>
defaultAdvisor
</
value
>
</
list
>
</
property
>
</
bean
>
</
beans
>






























NameMatchMethodPointcut只有一个属性mappedName或者mappedNames,前者表示映射单个字符串,后者表示映射一组字符串,支持<list>配置,这里“business*”表示所有business开头的方法,这里的“*”是通配符不是正则表达式,可以看出DefaultPointcutAdvisor的配置也很简单,就是给advice属性指定为beforeAdvice也就是前置通知,同时给pointcut属性指向了配置的NameMatchMethodPointcut。
2、org.springframework.aop.support.JdkRegexpMethodPointcut、
org.springframework.aop.support.Perl5RegexpMethodPointcut
由于这2个都是正则表达式切入点的描述,所以这里就放到一起对比讲解,JdkRegexpMethodPointcut需要在 JDK1.4 及以上的环境运行,不需要额外的库;Perl5RegexpMethodPointcut需要把 jakarta-oro-xx.jar 文件放到 classpath 上,比如 jakarta-oro-2.0.8.jar,这2个正则表达式切入点描述类的使用方法一样,他们均有2个属性:
(1) pattern或patterns:前者表示单个正则表达式,后置表示多个正则表达式,支持<list>配置;
(2) ExcludedPattern或ExcludedPatterns:前者表示排除某个字符串,后者表示排除一组字符串,支持<list>配置;
根据上面的讲述我们将前面的NameMatchMethodPoint改成JdkRegexpMethodPointcut和Perl5RegexpMethodPointcut配置,分别如下:
JdkRegexpMethodPointcut配置:











这里表示匹配所有
business
开头的方法但是除去了
business2
这个方法,其他的配置和
NameMatchMethodPointcut
一样。
Perl5RegexpMethodPointcut配置:











这里只需要给class换成
org.springframework.aop.support. Perl5RegexpMethodPointcut就可以了,同时在classpath中要添加jakarta-oro-xx.jar文件,其他的不需要做任何改变。
3、org.springframework.aop.support.ExpressionPointcut
在 Spring2 中,在 Pointcut 的基础上,引入了一个 ExpressionPointcut 接口用来通过切入点表达语言来描述切入点。有了 ExpressionPointcut,我们可以使用下面更加简单的方式来描述切入点,如 execution(* Component.business*(..))表示执行所有 Component 的业务方法(此处为 business 打头的方法)。
Spring2 提供了一个 ExpressionPointcut 的实现,即 AspectJExpressionPointcut,该类的使用很简单,只需要做如下配置即可:








其他的配置和前面的几个均一样。
除了以上4种不同的切入点的应用,还可以自定义切入点进行某些特殊的运用,自定义切入点类只需要实现org.springframework.aop.pointcut类,然后再bean中声明该类,接着就可以使用这些自定的pointcut类了。
文章系erikchang所有,EasyJF版权所有,转载请注明出处!
觉得很有用,就转了.