spring对AOP的实现提供了很好的支持。下面我们就使用Spring的注解来完成AOP做一个例子。
首先,为了使用Spring的AOP注解功能,必须导入如下几个包。aspectjrt.jar,aspectjweaver.jar,cglib-nodep.jar.然后我们写一个接口
package com.bird.service; public interface PersonServer { public void save(String name); public void update(String name, Integer id); public String getPersonName(Integer id); }
和一个接口实现类
package com.bird.service.impl; import com.bird.service.PersonServer; public class PersonServiceBean implements PersonServer{ @Override public void save(String name) { System.out.println("我是save方法"); // throw new RuntimeException(); } @Override public void update(String name, Integer id) { System.out.println("我是update()方法"); } @Override public String getPersonName(Integer id) { System.out.println("我是getPersonName()方法"); return "xxx"; } }
下面使用Spring注解方式对这个Bean进行方法拦截
package com.bird.service; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; /** * 切面 * @author Bird * */ @Aspect public class MyInterceptor { @Pointcut("execution(* com.bird.service.impl.PersonServiceBean.*(..))") private void anyMethod(){}//定义一个切入点 @Before("anyMethod() && args(name)") public void doAccessCheck(String name){ System.out.println(name); System.out.println("前置通知"); } @AfterReturning("anyMethod()") public void doAfter(){ System.out.println("后置通知"); } @After("anyMethod()") public void after(){ System.out.println("最终通知"); } @AfterThrowing("anyMethod()") public void doAfterThrow(){ System.out.println("例外通知"); } @Around("anyMethod()") public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable{ System.out.println("进入环绕通知"); Object object = pjp.proceed();//执行该方法 System.out.println("退出方法"); return object; } }
@Pointcut("execution(* com.bird.service.impl.PersonServiceBean.*(..))")
这句话是方法切入点,execution为执行的意思,*代表任意返回值,然后是包名,.*意思是包下面的所有子包。(..)代表各种方法。然后下面的注解就比较简单了,就是在使用方法前和中,还有环绕拦截/,然后在Spring的配置文件中继续配置Bean,需要打开AOP命名空间
<?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:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd"> <aop:aspectj-autoproxy/> <bean id="personServiceBean" class="com.bird.service.impl.PersonServiceBean"/> <bean id="myInterceptor" class="com.bird.service.MyInterceptor"/> </beans>
然后建立一个Junit测试
package junit.test; import org.junit.Test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.bird.service.PersonServer; public class SpringAOPTest { @Test public void inteceptorTest(){ ApplicationContext ctx = new ClassPathXmlApplicationContext("beanAop.xml"); PersonServer bean = (PersonServer)ctx.getBean("personServiceBean"); bean.save(null); } }
测试结果为
2012-3-12 18:08:39 org.springframework.context.support.AbstractApplicationContext prepareRefresh 信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@dd20f6: display name [org.springframework.context.support.ClassPathXmlApplicationContext@dd20f6]; startup date [Mon Mar 12 18:08:39 CST 2012]; root of context hierarchy 2012-3-12 18:08:40 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions 信息: Loading XML bean definitions from class path resource [beanAop.xml] 2012-3-12 18:08:40 org.springframework.context.support.AbstractApplicationContext obtainFreshBeanFactory 信息: Bean factory for application context [org.springframework.context.support.ClassPathXmlApplicationContext@dd20f6]: org.springframework.beans.factory.support.DefaultListableBeanFactory@b0bad7 2012-3-12 18:08:40 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons 信息: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@b0bad7: defining beans [org.springframework.aop.config.internalAutoProxyCreator,personServiceBean,myInterceptor]; root of factory hierarchy null 前置通知 进入环绕通知 我是save方法 后置通知 退出方法 最终通知
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍spring AOP自定义注解方式实现日志管理的实例讲解,包括了spring AOP自定义注解方式实现日志管理的实例讲解的使用技巧和注意事项,需要的朋友参考一下 今天继续实现AOP,到这里我个人认为是最灵活,可扩展的方式了,就拿日志管理来说,用Spring AOP 自定义注解形式实现日志管理。废话不多说,直接开始!!! 关于配置我还是的再说一遍。 在applicationContex
本文向大家介绍aop注解方式实现全局日志管理方法,包括了aop注解方式实现全局日志管理方法的使用技巧和注意事项,需要的朋友参考一下 1:日志实体类 2:maven需要的jar 这里要求项目使用的是jdk1.7 3:springServlet-mvc.xml 加上proxy-target-class="true"是为了可以拦截controller里面的方法 4:定义切面,我这里主要写前置通知和异常通
本文向大家介绍Spring AOP的几种实现方式总结,包括了Spring AOP的几种实现方式总结的使用技巧和注意事项,需要的朋友参考一下 AOP核心概念 1、横切关注点 对哪些方法进行拦截,拦截后怎么处理,这些关注点称之为横切关注点 2、切面(aspect) 类是对物体特征的抽象,切面就是对横切关注点的抽象 3、连接点(joinpoint) 被拦截到的点,因为spring只支持方法类型的连接点,
本文向大家介绍spring aop之链式调用的实现,包括了spring aop之链式调用的实现的使用技巧和注意事项,需要的朋友参考一下 概述 AOP(Aspect Orient Programming),我们一般称为面向方面(切面)编程,作为面向对象的一种补充,用于处理系统中分布于各个模块的横切关注点,比如事务管理、日志、缓存等等。 Spring AOP采用的是动态代理,在运行期间对业务方法进行增
本文向大家介绍详解Spring学习总结——Spring实现AOP的多种方式,包括了详解Spring学习总结——Spring实现AOP的多种方式的使用技巧和注意事项,需要的朋友参考一下 目录 一、基于XML配置的Spring AOP 二、使用注解配置AOP 三、AspectJ切点函数 四、AspectJ通知注解 五、零配置实现Spring IoC与AOP AOP(Aspect Oriented Pr
主要内容:基于XML模式,声明一个方面(Aspects),声明一个切入点,声明通知,基于@AspectJ,声明一个方面(aspect),声明一个切入点,声明通知Spring支持使用注释样式方法和基于模式的方法来实现自定义方面。 基于XML模式 方面()使用常规类以及基于XML的配置来实现。 要使用本节中描述的命名空间标签,您需要按照以下所述导入模式: 声明一个方面() 使用元素声明一个方面(),并使用属性引用后台,如下所示: 这个“”将被配置和依赖注入就像任何其他的一样,就像在前几章中看到的一样