spring aop学习的第一个例子

首先是接口定义:
package  com.gc.impl;

public   interface  FinanceInterface  {

    
public void doCheck(String name);
    
public void doSaying();
}

 

然后是接口实现类:

 

package  com.gc.action;

import  com.gc.impl. * ;

public   class  Finance  implements  FinanceInterface {

    
public void doCheck(String name)
    
{
        System.out.println(
"doChecking...");
    }

    
    
public void doSaying()
    
{
        System.out.println(
"doSaying...");
    }

}

 接着是插入到切入点的代码(即通知 advice)本例中用的是前后都有通知的方式:(当然可以用不同的通知方式)

 

package  com.gc.action;

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

public   class  LogAround  implements  MethodInterceptor {

    
public Object invoke(MethodInvocation mi)throws Throwable
    
{
        System.out.println(
"Starting...");
        
try
        
{
            Object result
=mi.proceed();
            
return result;
        }

        
finally
        
{
            System.out.println(
"Ending...");
        }

    }

}

 

接着是最重要的xml配置文件:

 

<? xml version="1.0" encoding="UTF-8" ?>
<! DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd" >

< beans >
  
< bean  id ="log"  class ="com.gc.action.LogAround"   />
  
< bean  id ="Finance"  class ="com.gc.action.Finance"   />
  
  <!-- 这里是先定义一个适配器(advisor)然后用来赋给下面bean中interceptorNames属性的value
   从这里也可以看出适配器其实就是一个定义advice和切入点之间关系的一个bean而已,没什么神秘的东西...
       -->
  
< bean  id ="logAdvisor"  class ="org.springframework.aop.support.RegexpMethodPointcutAdvisor" >
      
< property  name ="advice" >
         
< ref  bean ="log"   />
      
</ property >
      
< property  name ="patterns" >
         
< value > .*doSaying.* </ value >
      
</ property >
  
</ bean >
   
   
  
< bean  id ="logProxy1"  class ="org.springframework.aop.framework.ProxyFactoryBean" >
      
< property  name ="proxyInterfaces" >
           
< value > com.gc.impl.FinanceInterface </ value >
      
</ property >
      
< property  name ="target" >
           
< ref  bean ="Finance"   />
      
</ property >
      
< property  name ="interceptorNames" >
         
< list >
           
< value > logAdvisor </ value >
         
</ list >
      
</ property >
  
</ bean >
</ beans >

 

最后是测试类:

 

package  com.gc.action;

import  org.springframework.context.ApplicationContext;
import  org.springframework.context.support.FileSystemXmlApplicationContext;

import  com.gc.impl.FinanceInterface;

public   class  TestFinance  {

    
/**
     * 
@param args
     
*/

    
public static void main(String[] args) {
        
// TODO Auto-generated method stub

        ApplicationContext acxt
=new FileSystemXmlApplicationContext("applicationContext.xml");
        FinanceInterface fi
=(FinanceInterface)acxt.getBean("logProxy1");
        fi.doCheck(
"");  //因为在xml文件中配置的方法中本方法不对应所以它不适合文件中配置的通知,所以没有输出通知的内容!
        
        System.out.println();
        fi.doSaying();
    }


}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值