使用Spring的注解方式实现AOP实例

 更新时间:2017年06月01日 10:40:10   作者:Bird  
本篇文章主要介绍了使用Spring的注解方式实现AOP实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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方法 
后置通知 
退出方法 
最终通知 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 深入探究TimSort对归并排序算法的优化及Java实现

    深入探究TimSort对归并排序算法的优化及Java实现

    这篇文章主要介绍了TimSort归并排序的优化及Java实现,TimSort 是一个归并排序做了大量优化的版本,需要的朋友可以参考下
    2016-05-05
  • hibernate4基本配置方式详解

    hibernate4基本配置方式详解

    这篇文章给大家带来了hibernate4基本配置方式,非常不错,具有参考借鉴价值,需要的额朋友参考下吧
    2017-09-09
  • 详解Java 中的UnitTest 和 PowerMock

    详解Java 中的UnitTest 和 PowerMock

    这篇文章主要介绍了Java中的 UnitTest 和 PowerMock,文中讲解非常详细,对大家学习有很大的帮助,感兴趣的朋友可以了解下
    2020-06-06
  • Java实现的简单掷骰子游戏示例

    Java实现的简单掷骰子游戏示例

    这篇文章主要介绍了Java实现的简单掷骰子游戏,涉及Java随机数的简单生成、运算与判定相关操作技巧,需要的朋友可以参考下
    2018-01-01
  • springboot mybatis里localdatetime序列化问题的解决

    springboot mybatis里localdatetime序列化问题的解决

    这篇文章主要介绍了springboot mybatis里localdatetime序列化问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • Spring Boot整合Redis的完整步骤

    Spring Boot整合Redis的完整步骤

    这篇文章主要给大家介绍了关于Spring Boot整合Redis的完整步骤,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • Java 类在 Tomcat 中是如何加载的(过程分析)

    Java 类在 Tomcat 中是如何加载的(过程分析)

    这篇文章主要介绍了Java 类在 Tomcat 中是如何加载的过程分析,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • springboot 定时任务@Scheduled实现解析

    springboot 定时任务@Scheduled实现解析

    这篇文章主要介绍了springboot 定时任务@Scheduled实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • SpringBoot集成slf4j+log4j2的示例代码

    SpringBoot集成slf4j+log4j2的示例代码

    这篇文章主要介绍了SpringBoot集成slf4j+log4j2的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • Java中数组与集合的相互转换实现解析

    Java中数组与集合的相互转换实现解析

    这篇文章主要介绍了Java中数组与集合的相互转换实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08

最新评论