Spring AOP 入门(2)

1。Person.java,PersonImpl.java,见Spring AOP 入门。

2.AopAdvisor .java

package com.zy.aop;
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;

public class AopAdvisor implements  MethodInterceptor {

 public Object invoke(MethodInvocation method) throws Throwable {
  // TODO Auto-generated method stub
  
  long executeStartTime = System.currentTimeMillis();
  Object retVal = method.proceed();
        long executeEndTime = System.currentTimeMillis();
  
  if(method.getMethod().getName().equals("run")){
   startRun(method.getArguments()[0], executeStartTime,
     executeEndTime, (String)retVal);
  }
  return retVal;
 }
 private void startRun(Object arg, long executeStartTime,
   long executeEndTime, String retVal){
  System.out.println("方法run执行的时间为:"+(executeEndTime-executeStartTime));
  System.out.println("方法run执行时参数为:"+arg);
  System.out.println("方法run执行的返回值为:"+retVal);
 }
 
}

3。applicationContext-aop.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="personTarget" class="com.zy.aop.PersonImpl">
  <property name="name">
   <value>刘邦</value>
  </property>
  <property name="age">
   <value>50</value>
  </property>
 </bean>
 
 <bean id="testAdvisor" class="com.zy.aop.AopAdvisor"/>

 
 <bean id="person" class="org.springframework.aop.framework.ProxyFactoryBean">
  <property name="proxyInterfaces">
   <value>com.zy.aop.Person</value> 
  </property>
  <property name="interceptorNames">
   <list>
    <value>testAdvisor</value>
    <value>personTarget</value>
   </list>
  </property>
 </bean>

</beans>

4。Test.java

package com.zy.aop;

import java.util.regex.Pattern;

import org.hibernate.criterion.Expression;
import org.hibernate.criterion.SimpleExpression;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;

public class Test {

 public static void main(String[] args) throws MyException {
  // TODO Auto-generated method stub
  ApplicationContext ctx = new FileSystemXmlApplicationContext("applicationContext-aop.xml");
  
  Person person = (Person) ctx.getBean("person");
  person.run(9);

 }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值