aspectj框架的aop开发方式有几种,spring aop aspect

  aspectj框架的aop开发方式有几种,spring aop aspect

  

目录

AspectJ简介注释开发环境准备不同的通知类型。在most通知中,切点的条目列表是由value属性@ pre-notification @ After returning post-notification @ Around contouring notification @ After throwing exception throwing notification @ After final notification @ Pointcut为切点命名AspectJ来定义的。基于XML的AOP开发使用AspectJ在注解方式,XML方式实现AOP

 

  

AspectJ简介

AspectJ是一个基于Java语言的AOP框架。在Spring2.0之后,增加了对AspectJ切入点表达式的支持。@AspectJ是AspectJ1.5的新功能,通过JDK5注释技术,允许在Bean类中直接定义新版本的Spring框架。推荐AspectJ开发AOP。使用AspectJ,需要导入Spring AOP和AspectJ相关的jar包,Spring-aopspringsource . org . aopalliancespringsource . org . AspectJ . weaver。

 

  

注解开发

 

  00-1010相关的jar包junit,javax.annotation-api,spring-core,spring-beans,spring-context,spring-expression,aopalliance,spring-aop(Spring基础包)AspectJ Weaver,Spring-AspectJ使用的Spring-aspects和Spring-test(test使用的)XML应该引入到相应的配置中?xml版本=1.0 编码=UTF-8 ?bean s xmlns= http://www . spring framework . org/schema/beans xmlns : xsi= http://www . w3 . org/2001/XML schema-instance xmlns : AOP= http://www . spring framework . org/schema/AOP xsi : schema location= http://www.springframework.org/schema/bean s http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd!-此处为bean定义-!-需要单独介绍-AOP : AspectJ-autoproxy//beans

  

环境准备

@ pre-notification,相当于Before advice @ AfterReturning post-notification,相当于AfterReturningAdvice@Around通知,相当于MethodInterceptor(可以阻止方法的进度,功能最强。列:事务管理)@AfterThrowing异常抛出一个通知,相当于在最终通知后抛出advice@。无论是否异常,这个通知都会执行@ DeclarwParents引入通知,相当于IntroductionInterceptor。

 

  00-1010通过执行函数,可以定义切点的切入语法:-执行(访问修饰符?返回类型方法名(参数)异常)(可以省略访问修饰符)列如-匹配所有类公共方法执行(publish * *(.))-first *:任意返回值second *:任意名称(.)3360任何参数等同于所有以public开头的方法都会被执行如果加了预先通知——匹配所有类方法执行(* top.odliken.demo .(.))在指定的包下。不包含子包.3360包-执行(* Top.odliken.demo.(.)) .它是包和子包下的所有类——匹配的指定类(top。奥德林。演示。用户服务。(.)).第一个*:任何返回值userservice。所有方法UserService。UserService类-特定接口(

  .odliken.demo.GenericDao+.(..)) +:子类 .:方法名 --匹配所有save开头的方法 execution(* save*(..))

  

 

  

入门案列

============XML==========<!--配置目标类=================--><bean id="customerDao" class="com.imooc.aspectJ.demo2.CustomerDaoImpl"/><!--配置切面类--><bean id="myAspectXml" class="com.imooc.aspectJ.demo2.MyAspectXml"/>===========ProductDao===========public class ProductDao { public void save() { System.out.println("保存商品....."); } public void findOne() { System.out.println("查找一个商品....."); } public void findAll() { System.out.println("查找所有商品....."); } public void update() { System.out.println("修改商品....."); } public void delete() { System.out.println("删除商品....."); }}===========MyAspectAnno===========@Aspectpublic class MyAspectAnno { @Before(value = "execution(* top.odliken.aspectJ.demo1.ProductDao.save(..))") public void before(){ System.out.println("=========前置通知========="); }}===========Springdemo1===========@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration("classpath:afterglow.xml")public class Springdemo1 { @Resource(name = "productDao") private ProductDao productDao; @Test public void demo1(){ productDao.save(); productDao.findOne(); productDao.findAll(); productDao.update(); productDao.delete(); }}

 

  

@Before前置通知

可以在方法中传入JoinPoint对象,用来获取切点信息

public void before(JoinPoint joinPoint){ System.out.println("=========前置通知========="+joinPoint);}

 

  

@AfterReturning后置通知

通过returning属性可以定义返回值,作为参数

@AfterReturning(value = "execution(* top.odliken.aspectJ.demo1.ProductDao.update(..))",returning = "result")public void afterReturing(Object result){ System.out.println("==========后置通知=========="+result);}

 

  

@Around环绕通知

Around方法的返回值就是目标代理方法执行返回值参数ProceedingJoinPoint 可以调用拦截目标方法执行如果不调用 ProceedingJoinPoint的 proceed方法,那么目标方法就背拦截了

@Around(value = "execution(* top.odliken.aspectJ.demo1.ProductDao.delete(..)))")public Object around(ProceedingJoinPoint joinPoint) throws Throwable { System.out.println("环绕通知======前"); Object obj = joinPoint.proceed();//执行目标方法 不调用就不执行 System.out.println("环绕通知======后"); return obj;}

 

  

@AfterThrowing 异常抛出通知

通过设置throwing属性,可以设置发生异常对象参数

@AfterThrowing(value = "execution(* top.odliken.aspectJ.demo1.ProductDao.findOne(..)))",throwing = "e")public void afterThrowing(Throwable e){ System.out.println("==========异常通知=========="+e.getMessage());}

 

  

@After 最终通知

无论是否出现异常,最终通知总是会被执行的。就像Java异常中的 finall块一样

@After(value = "execution(* top.odliken.aspectJ.demo1.ProductDao.findAll(..))")public void after(){ System.out.println("==========最终通知==========");}

 

  

通过@Pointcut为切点命名

在每个通知内定义切点,会造成工作量大,不易维护,对于重复的切点,可以使用@Pointcut进行定义切点方法:private void 无参方法,方法名为切点名当通知多个切点是,可以使用连接

@Before(value = "myPointcut1()")public void before(JoinPoint joinPoint){ System.out.println("=========前置通知========="+joinPoint);}@Pointcut(value = "execution(* top.odliken.aspectJ.demo1.ProductDao.save(..))")private void myPointcut1(){}

 

  

AspectJ的XML方式的AOP开发

==========CustomerDao==========public interface CustomerDao { public void save(); public String update(); public void delete(); public void findOne(); public void findAll();}==========CustomerDaoImpl==========public class CustomerDaoImpl implements CustomerDao { public void save() { System.out.println("保存客户..."); } public String update() { System.out.println("修改客户..."); return "spring"; } public void delete() { System.out.println("删除客户..."); } public void findOne() { System.out.println("查询一个客户...");// int a = 1/ 0; } public void findAll() { System.out.println("查询多个客户...");// int b = 1/0; }}==========MyAspectXml==========public class MyAspectXml { // 前置通知 public void before(JoinPoint joinPoint) { System.out.println("XML方式的前置通知==============" + joinPoint); } // 后置通知 public void afterReturing(Object result) { System.out.println("XML方式的后置通知==============" + result); } // 环绕通知 public Object around(ProceedingJoinPoint joinPoint) throws Throwable { System.out.println("XML方式的环绕前通知=============="); Object obj = joinPoint.proceed(); System.out.println("XML方式的环绕后通知=============="); return obj; } // 异常抛出通知 public void afterThrowing(Throwable e) { System.out.println("XML方式的异常抛出通知=============" + e.getMessage()); } // 最终通知 public void after() { System.out.println("XML方式的最终通知================="); }}==========SpringDemo2==========@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(value="classpath:applicationContext2.xml")public class SpringDemo2 { @Resource(name="customerDao") private CustomerDao customerDao; @Test public void demo1(){ customerDao.save(); customerDao.update(); customerDao.delete(); customerDao.findOne(); customerDao.findAll(); }}==========XML==========<!--XML的配置方式完成AOP的开发===============--><!--配置目标类=================--><bean id="customerDao" class="com.imooc.aspectJ.demo2.CustomerDaoImpl"/><!--配置切面类--><bean id="myAspectXml" class="com.imooc.aspectJ.demo2.MyAspectXml"/><!--aop的相关配置=================--><aop:config> <!--配置切入点--> <aop:pointcut id="pointcut1" expression="execution(* com.imooc.aspectJ.demo2.CustomerDao.save(..))"/> <aop:pointcut id="pointcut2" expression="execution(* com.imooc.aspectJ.demo2.CustomerDao.update(..))"/> <aop:pointcut id="pointcut3" expression="execution(* com.imooc.aspectJ.demo2.CustomerDao.delete(..))"/> <aop:pointcut id="pointcut4" expression="execution(* com.imooc.aspectJ.demo2.CustomerDao.findOne(..))"/> <aop:pointcut id="pointcut5" expression="execution(* com.imooc.aspectJ.demo2.CustomerDao.findAll(..))"/> <!--配置AOP的切面--> <aop:aspect ref="myAspectXml"> <!--配置前置通知--> <aop:before method="before" pointcut-ref="pointcut1"/> <!--配置后置通知--> <aop:after-returning method="afterReturing" pointcut-ref="pointcut2" returning="result"/> <!--配置环绕通知--> <aop:around method="around" pointcut-ref="pointcut3"/> <!--配置异常抛出通知--> <aop:after-throwing method="afterThrowing" pointcut-ref="pointcut4" throwing="e"/> <!--配置最终通知--> <aop:after method="after" pointcut-ref="pointcut5"/> </aop:aspect></aop:config>

到此这篇关于Spring的基于AspectJ的AOP开发的文章就介绍到这了,更多相关Spring基于AspectJ的AOP开发内容请搜索盛行IT以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT!

 

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • spring编程式事务处理,spring编程事务
  • spring编程式事务处理,spring编程事务,详解Spring学习之编程式事务管理
  • spring的核心功能模块有几个,列举一些重要的spring模块
  • spring的核心功能模块有几个,列举一些重要的spring模块,七个Spring核心模块详解
  • spring注解和springmvc的注解,SpringMVC常用注解
  • spring注解和springmvc的注解,SpringMVC常用注解,详解springmvc常用5种注解
  • spring实现ioc的四种方法,spring的ioc的三种实现方式
  • spring实现ioc的四种方法,spring的ioc的三种实现方式,简单实现Spring的IOC原理详解
  • spring事务失效问题分析及解决方案怎么做,spring 事务失效情况
  • spring事务失效问题分析及解决方案怎么做,spring 事务失效情况,Spring事务失效问题分析及解决方案
  • spring5.0新特性,spring4新特性
  • spring5.0新特性,spring4新特性,spring5新特性全面介绍
  • spring ioc以及aop原理,springmvc aop原理
  • spring ioc以及aop原理,springmvc aop原理,深入浅析Spring 的aop实现原理
  • Spring cloud网关,spring cloud zuul作用
  • 留言与评论(共有 条评论)
       
    验证码: