使用Spring(15) Spring AOP APIs(NameMatchMethodPointcutAdvisor,RegexpMethodPointcutAdvisor))

前置通知和后置通知与前一篇文章中一样,省略不写了。

1.applicationContext.xml


NameMatchMethodPointcutAdvisor

<?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"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

	<bean id="he" class="com.yw.test12.HelloImpl"></bean>
	<bean id="sba" class="com.yw.test12.SayBeforeAdvice"></bean>
	<bean id="saa" class="com.yw.test12.SayAfterAdvice"></bean>
	<bean id="saa2" class="com.yw.test12.SayAroundAdvice"></bean>

	<bean id="helloPerson"
		class="org.springframework.aop.support.NameMatchMethodPointcutAdvisor">
		<property name="mappedName">
			<value>hello*</value>
		</property>
		<property name="advice">
			<ref bean="saa2" />
		</property>
	</bean>




	<!-- 像其它的FactoryBean实现一样,ProxyFactoryBean引入了一个间接层。如果你定义一个名为foo的ProxyFactoryBean, 
		引用foo的对象看到的将不是ProxyFactoryBean实例本身,而是一个ProxyFactoryBean实现里getObject() 方法所创建的对象。 
		这个方法将创建一个AOP代理,它包装了一个目标对象。 使用ProxyFactoryBean或者其它IoC相关类带来的最重要的好处之一就是创建AOP代理,这意味着通知和切入点也可以由IoC来管理。 -->
	<bean id="helloProxy" class="org.springframework.aop.framework.ProxyFactoryBean">

		<!-- proxyInterfaces:需要代理的接口名的字符串数组。如果没有提供,将为目标类使用一个CGLIB代理 -->
		<property name="proxyInterfaces">
			<value>com.yw.test12.Hello</value>
		</property>


		<property name="target">
			<ref bean="he" />
		</property>

		<!-- interceptorNames:Advisor的字符串数组,可以包括拦截器或其它通知的名字。顺序是很重要的,排在前面的将被优先服务。就是说列表里的第一个拦截器将能够第一个拦截调用。 
			这里的名字是当前工厂中bean的名字,包括父工厂中bean的名字。这里你不能使用bean的引用因为这会导致ProxyFactoryBean忽略通知的单例设置。 
			你可以把一个拦截器的名字加上一个星号作为后缀(*)。这将导致这个应用程序里所有名字以星号之前部分开头的advisor都被应用。你可以在第 7.5.6 
			节 “使用“全局”advisor” 发现一个使用这个特性的例子。 -->

		<property name="interceptorNames">
			<list>
				<!-- <value>sba</value> <value>saa</value> -->
				<!-- <value>saa2</value> -->
				<value>helloPerson</value>
			</list>
		</property>
	</bean>

</beans>


2.

package com.yw.test12;

public interface Hello
{
	void helloChina(String str);
	void helloAmerican(String str);
}

package com.yw.test12;

public class HelloImpl implements Hello
{


	@Override
	public void helloChina(String str)
	{
		System.out.println("你好中国"+str);
		
	}

	@Override
	public void helloAmerican(String str)
	{
		System.out.println("你好美国"+str);
		
	}

}

package com.yw.test12;

import java.lang.reflect.Method;

import net.sf.cglib.proxy.MethodProxy;

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;

public class SayAroundAdvice implements MethodInterceptor
{

	@Override
	public Object invoke(MethodInvocation arg0) throws Throwable
	{
		System.out.println("在方法执行前做事情.");
		arg0.proceed();

		System.out.println("在方法执行后做事情.");
		return null;
	}

}

3.运行如图



==================================================

1.applicationContext.xml


RegexpMethodPointcutAdvisor


<?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"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

	<bean id="he" class="com.yw.test13.HelloImpl"></bean>
	<bean id="sba" class="com.yw.test13.SayBeforeAdvice"></bean>
	<bean id="saa" class="com.yw.test13.SayAfterAdvice"></bean>
	<bean id="saa2" class="com.yw.test13.SayAroundAdvice"></bean>

	<bean id="helloPerson"
		class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">
		<property name="pattern">
			<value>.*hello.*</value>
		</property>
		<property name="advice">
			<ref bean="saa2" />
		</property>
	</bean>




	<!-- 像其它的FactoryBean实现一样,ProxyFactoryBean引入了一个间接层。如果你定义一个名为foo的ProxyFactoryBean, 
		引用foo的对象看到的将不是ProxyFactoryBean实例本身,而是一个ProxyFactoryBean实现里getObject() 方法所创建的对象。 
		这个方法将创建一个AOP代理,它包装了一个目标对象。 使用ProxyFactoryBean或者其它IoC相关类带来的最重要的好处之一就是创建AOP代理,这意味着通知和切入点也可以由IoC来管理。 -->
	<bean id="helloProxy" class="org.springframework.aop.framework.ProxyFactoryBean">

		<!-- proxyInterfaces:需要代理的接口名的字符串数组。如果没有提供,将为目标类使用一个CGLIB代理 -->
		<property name="proxyInterfaces">
			<value>com.yw.test13.Hello</value>
		</property>


		<property name="target">
			<ref bean="he" />
		</property>

		<!-- interceptorNames:Advisor的字符串数组,可以包括拦截器或其它通知的名字。顺序是很重要的,排在前面的将被优先服务。就是说列表里的第一个拦截器将能够第一个拦截调用。 
			这里的名字是当前工厂中bean的名字,包括父工厂中bean的名字。这里你不能使用bean的引用因为这会导致ProxyFactoryBean忽略通知的单例设置。 
			你可以把一个拦截器的名字加上一个星号作为后缀(*)。这将导致这个应用程序里所有名字以星号之前部分开头的advisor都被应用。你可以在第 7.5.6 
			节 “使用“全局”advisor” 发现一个使用这个特性的例子。 -->

		<property name="interceptorNames">
			<list>
				<!-- <value>sba</value> <value>saa</value> -->
				<!-- <value>saa2</value> -->
				<value>helloPerson</value>
			</list>
		</property>
	</bean>

</beans>


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值