AOP学习笔记

1、依赖配置方式

测试方法:

public void test1() {
  String filePath = System.getProperty("user.dir") + File.separator + "src/com/dmeo/aop"
   + File.separator + "spring.xml";
  BeanFactory factory = new XmlBeanFactory(new FileSystemResource(filePath));

  Shopping shopping = null;
  System.out.println("不使用任何通知");
  shopping = (Shopping) factory.getBean("shoppingImpl");
  shopping.buySomething("something");
  //    shopping.buyAnything("anything");

 

....................................................................

 

spring.xml

<bean id="welcomeAdvice" class="com.dmeo.aop.WelcomeAdvice" />
 <bean id="welcomeAdviceShop"
  class="org.springframework.aop.framework.ProxyFactoryBean">
  <property name="target">
   <ref local="shoppingImpl" />
  </property>
  
  <!-- 以下属性没有的话不会出错,interceptorNames如果没有配置,target的方法就不会被拦截 -->
  <property name="proxyInterfaces">
   <value>com.dmeo.aop.Shopping</value>
  </property>
  <property name="interceptorNames">
   <list>
    <value>welcomeAdvice</value>
   </list>
  </property>
 </bean>

 

2.不干涉原先的bean配置,AOP真正的强悍啊,可以用来测试,添加日志等

1).单个通知

<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns:tx="http://www.springframework.org/schema/tx"
 xmlns:aop="http://www.springframework.org/schema/aop"
 xmlns:jee="http://www.springframework.org/schema/jee"
 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd
 http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
 http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.0.xsd">

 <bean id="customer" class="com.dmeo.aop.Customer">
  <constructor-arg index="0">
   <value>xh</value>
  </constructor-arg>
  <constructor-arg index="1">
   <value>26</value>
  </constructor-arg>
 </bean>

 <bean id="shoppingImpl" class="com.dmeo.aop.ShoppingImpl">
  <property name="customer">
   <ref local="customer" />
  </property>
 </bean>

 

 

 

 

 

 

下面给出对切面的所有行为进行拦截通知。

 

2).多个通知一起拦截

<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"
 xsi:schemaLocation="
            http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
            http://www.springframework.org/schema/aop
            http://www.springframework.org/schema/aop/spring-aop-2.5.xsd"
 default-autowire="autodetect">

 

 <bean id="aService" class="com.dmeo.aop2.AServiceImpl"></bean>
 <bean id="bService" class="com.dmeo.aop2.BServiceImpl"></bean>
</beans>

 

测试类:

public static void main(String[] args) {
  String filePath = "com/dmeo/aop2/spring.xml";

 // 必须得用ApplicationContext
  ApplicationContext factory = new ClassPathXmlApplicationContext(filePath);

  aService = (AService) factory.getBean("aService");
  bService = (BServiceImpl) factory.getBean("bService");

  testThrow();
 }

 public static void testCall() {
  System.out.println("Spring AOP test");
  aService.fooA("test fooA");
  aService.barA();
  bService.fooB();
  bService.barB("test barB", 0);
 }

 public static void testThrow() {
  try {
   bService.barB("call barB", 1);
  } catch (IllegalArgumentException e) {
  }
 }

 

详细代码见附件~~~

 

重点说明:

《Spring参考手册》中定义了以下几个AOP的重要概念,结合以上代码分析如下:

    • :官方的抽象定义为“一个关注点的模块化,这个关注点可能会横切多个对象”,在本例中,“切面”就是类TestAspect所关注的具体行为,例如,AServiceImpl.barA()的调用就是切面TestAspect所关注的行为之一。“切面”在ApplicationContext中<aop:aspect>来配置。
:程序执行过程中的某一行为,例如,AServiceImpl.barA()的调用或者BServiceImpl.barB(String _msg, int _type)抛出异常等行为。 :“切面”对于某个“连接点”所产生的动作,例如,TestAspect中对com.spring.service包下所有类的方法进行日志记录的动作就是一个Advice。其中,一个“切面”可以包含多个“Advice”,例如TestAspect :匹配连接点的断言,在AOP中通知和一个切入点表达式关联。例如,TestAspect中的所有通知所关注的连接点,都由切入点表达式execution(* com.spring.service.*.*(..))来决定 :被一个或者多个切面所通知的对象。例如,AServcieImpl和BServiceImpl,当然在实际运行时,Spring AOP采用代理实现,实际AOP操作的是TargetObject的代理对象。 在Spring AOP中有两种代理方式,JDK动态代理和CGLIB代理。默认情况下,TargetObject实现了接口时,则采用JDK动态代理,例如,AServiceImpl;反之,采用CGLIB代理,例如,BServiceImpl。强制使用CGLIB代理需要将 <aop:config>proxy-target-class 属性设为true

 execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern) throws-pattern?)

modifiers-pattern:方法的操作权限

ret-type-pattern:返回值

declaring-type-pattern:方法所在的包

name-pattern:方法名

parm-pattern:参数名

throws-pattern:异常

其中,除ret-type-pattern和name-pattern之外,其他都是可选的。上例中,execution(* com.spring.service.*.*(..))表示com.spring.service包下,返回值为任意类型;方法名任意;参数不作限制的所有方法。

具体请点击:http://www.verydemo.com/demo_c143_i5776.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值