Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2860126
  • 博文数量: 471
  • 博客积分: 7081
  • 博客等级: 少将
  • 技术积分: 5369
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-04 21:55
文章分类

全部博文(471)

文章存档

2014年(90)

2013年(69)

2012年(312)

分类: Java

2012-03-11 22:42:39

beans.xml文件的配置

点击(此处)折叠或打开

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns=""
  3.        xmlns:xsi=""
  4.        xmlns:context=""
  5.        xmlns:aop=""
  6.        xsi:schemaLocation="
  7.            /spring-beans-2.5.xsd
  8.             /spring-context-2.5.xsd
  9.             /spring-aop-2.5.xsd">
  10.         <aop:aspectj-autoproxy/>
  11.         <bean id="personService" class="cn.itcast.service.impl.PersonServiceBean"></bean>
  12.         <bean id="aspetbean" class="cn.itcast.service.MyInterceptor"/>
  13.         <aop:config>
  14.             <aop:aspect id="asp" ref="aspetbean">
  15.                 <aop:pointcut id="mycut" expression="execution(* cn.itcast.service..*.*(..))"/>
  16.                 <aop:before pointcut-ref="mycut" method="doAccessCheck"/>
  17.                 <aop:after-returning pointcut-ref="mycut" method="doAfterReturning"/>
  18.                  <aop:after-throwing pointcut-ref="mycut" method="doAfterThrowing"/>
  19.                  <aop:after pointcut-ref="mycut" method="doAfter"/>
  20.                  <aop:around pointcut-ref="mycut" method="doBasicProfiling"/>
  21.             </aop:aspect>
  22.         </aop:config>
  23. </beans>
<aop:pointcut id="mycut" expression="execution(* cn.itcast.service..*.*(..))"/>
声明一个切入点,表达式表示拦截所有的返回类型,service文件下的所有子文件的类,的所有方法

切面就是一个pojo类

点击(此处)折叠或打开

  1. package cn.itcast.service;

  2. import org.aspectj.lang.ProceedingJoinPoint;
  3. /**
  4.  * 切面
  5.  *doBasicProfiling(ProceedingJoinPoint pjp)这个方法可以不要
  6.  *就不用引入相关的包
  7.  */
  8. public class MyInterceptor {    
  9.     public void doAccessCheck() {
  10.         System.out.println("前置通知");
  11.     }

  12.     public void doAfterReturning() {
  13.         System.out.println("后置通知");
  14.     }
  15.     
  16.     public void doAfter() {
  17.         System.out.println("最终通知");
  18.     }
  19.     
  20.     public void doAfterThrowing() {
  21.         System.out.println("例外通知");
  22.     }
  23.     
  24.     public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable {
  25.         System.out.println("进入方法");
  26.         Object result = pjp.proceed();
  27.         System.out.println("退出方法");
  28.         return result;
  29.     }
  30.     
  31. }
被切入的类

点击(此处)折叠或打开

  1. package cn.itcast.service.impl;

  2. import cn.itcast.service.PersonService;

  3. public class PersonServiceBean implements PersonService {

  4.     public String getPersonName(Integer id) {
  5.         System.out.println("我是getPersonName()方法");
  6.         return "xxx";
  7.     }

  8.     public void save(String name) {
  9.         //throw new RuntimeException("我爱例外");

  10.         System.out.println("我是save()方法");
  11.     }

  12.     public void update(String name, Integer id) {
  13.         System.out.println("我是update()方法");
  14.     }

  15. }

测试一下

点击(此处)折叠或打开

  1. package junit.test;


  2. import org.junit.BeforeClass;
  3. import org.junit.Test;
  4. import org.springframework.context.ApplicationContext;
  5. import org.springframework.context.support.ClassPathXmlApplicationContext;

  6. import cn.itcast.service.PersonService;

  7. public class SpringAOPTest {

  8.     @BeforeClass
  9.     public static void setUpBeforeClass() throws Exception {
  10.     }

  11.     @Test public void interceptorTest(){
  12.         ApplicationContext cxt = new ClassPathXmlApplicationContext("beans.xml");
  13.         PersonService personService = (PersonService)cxt.getBean("personService");
  14.         personService.getPersonName(2);
  15.         personService.update("king", 2);
  16.     }
  17. }
  18. log4j:WARN No appenders could be found for logger (org.springframework.context.support.ClassPathXmlApplicationContext).
    log4j:WARN Please initialize the log4j system properly.
    前置通知
    进入方法
    我是getPersonName()方法
    后置通知
    最终通知
    退出方法
    前置通知
    进入方法
    我是update()方法
    后置通知
    最终通知
    退出方法


 

 



 

 
阅读(462) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~