SpringAop切入点execution表达式的深入讲解

目录
  • 一、Aspect切入点语法定义
  • 二、如何定义多个切入点,在多个表达式之间如何表示
  • 三、execution表达式
  • 五、方法签名表达式
  • 六、其他替代的切入点指示符
  • 七、通配符
  • 总结

一、Aspect切入点语法定义

在使用spring框架配置AOP的时候,不管是通过XML配置文件形式,还是注解的方式都需要定义pointcut(切入点),pointcut称之为切入点。

例如 :

定义切入点表达式  :

execution (* com.sample.service.impl..*.*(..))

上面的execution()是最常用的切点函数,其语法如下所示:

整个表达式可以分为五个部分

1、execution():表达式主体。

2、第一个*号:表示返回类型,*号表示所有的类型。

3、包名:表示需要拦截的包名,后面的两个句点分别表示当前包和当前包的所有子包,com.sample.service.impl包、子孙包下所有类的方法。

4、第二个*号:表示类名,*号表示所有的类。

5、*(..) :第三个星号表示方法名,*号表示所有的方法,后面括弧里面表示方法的参数,两个句点表示任何参数。

下面给出一些常见切入点表达式的例子: 借鉴(https://smallbee.iteye.com/blog/2213078)

任意公共方法的执行:

execution(public * *(..))    : 表明任何返回类型、类名和参数的任何公共方法都将被通知。

任何一个以"set"开始的方法的执行:

execution(* set*(..))

AccountService接口的任意方法的执行:

execution(* com.xyz.service.AccountService.*(..))

定义在service包里的任意方法的执行:

execution(* com.xyz.service.*.*(..))

定义在service包或者子包里的任意类的任意方法的执行:

execution(* com.xyz.service..*.*(..))

二、如何定义多个切入点,在多个表达式之间如何表示

  • 使用 ||,   or表示 或
  • 使用 &&,and表示 与
  • 使用not,!表示 非

三、execution表达式

1、匹配指定包下所有类方法 :

execution(* com.baidu.dao.*(..)) 不包含子包

2.   匹配指定包以及及指定包下面的子包所有类 :

execution(* com.baidu.dao..*(..))  ..*表示当前包、子孙包下所有类

3、匹配指定类所有方法 :

execution(* com.baidu.service.UserService.*(..))

4、匹配实现特定接口所有类方法 :

execution(* com.baidu.dao.GenericDAO+.*(..))

5、匹配所有save开头的方法 :

execution(* save*(..))

另外,签名可分为类型签名和方法签名,下面介绍两种类型 的区别,参考自: https://www.jianshu.com/p/1ff6c1edbb7b

四、类型签名表达式

为了根据类型(比如接口、类名或者包名过滤方法),SpringAOP提供了Within关键字。类型签名模式如下,其中可以使用package name或者class name替换type name。

Within(<type name>)

接下来列举一些类型签名用法的示例:

  • within(net.yangki..*):该通知将匹配net.yangki包及其子包中所有类中的所有方法。
  • within(net.yangki.spring.demo.MyService):该通知将匹配MyService类中的所有方法。
  • within(MyServiceInterface+):该通知将匹配所有实现了MyServiceInterface接口的类的所有方法。
  • within(net.yangki.spring.demo.MyBaseService+):该通知将匹配MyBaseService类以及其子类的所有方法。

五、方法签名表达式

如果想根据方法签名进行过滤,可以使用关键字execution。模式如下:

execution(<scope><return-type><fully-qualified-class-name>.*(parameters))

此时,对于与给定的作用域、返回类型、完全限定类名以及参数相匹配的方法,都会应用指定的通知。方法的作用域可以是公共的、保护的或者私有的。如果不想使用参数过滤,可以指定两个点..,以表明方法可以接受任何数量和任何类型的参数。下面对方法签名的示例进行了简单的概述:

  • execute(* net.yangki.soring.demo.MyBean.*(..)):该通知将匹配MyBean中的所有方法。
  • execute(public * net.yangki.spring.demo.MyBean.*(..)):该通知将匹配MyBean中的所有公共方法。
  • execute(public String net.yangki.spring.demo.MyBean.*(..)):该通知将匹配MyBean中的所有返回值为String类型的公共方法。
  • execute(public * net.yangki.spring.demo.MyBean.*(long,..)):该通知将匹配MyBean第一个参数被定义为long的所有公共方法。

六、其他替代的切入点指示符

该部分将举例SpringAOP所支持的指示符。AOP仅支持在其他AOP项目中可用的指示符的一个子集。

  • bean(* Service):根据名称使用关键字bean进行过滤。该切入点表达式将与名称中带有后缀Service的Bean相匹配。
  • @annotation(net.yangki.spring.demo.MarkerMethodAnnotation):根据所应用的注解对方法进行过滤。该切入点表达式表明使用了MarkerMethodAnnotation注解的方法将被通知。
  • within(net.yangki.spring.demo.MarkerAnnotation):当带有关键字within的切入点表达式与一个包、类或者接口相匹配时,可以根据类所使用的注解限制对类的过滤。此时,使用了MarkerMethodAnnotation注解的类将被@within关键字通知。
  • This(net.yangki.spring.demo.MarkerInterface):该切入点表达式将对任何实现了MarkerInterface接口的代理对象的方法进行过滤。

七、通配符

在定义表达式时,还可以使用通配符。比如*、..或者+。如下表

通配符 定义
.. 该通配符匹配方法定义中的任何数量的参数,此外还匹配类定义中任何数量的包
+ 该通配符匹配给定类的任何子类
* 该通配符匹配任何数量的字符

总结

到此这篇关于SpringAop切入点execution表达式的文章就介绍到这了,更多相关SpringAop切入点execution表达式内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • springAOP中用joinpoint获取切入点方法的参数操作

    springAOP joinpoint获取切入点方法的参数 概念: 访问目标方法即用jointpoint(@around用poceedingjointpoint) 1.获取他们的目标对象信息, 如test.component@80387a这种 2.还有获取带参方法的参数, 如[Ljava.lang.Object;@183cfe9(想当然我们也可以用对象的arrays.toString()方法将其还原) 3.另外还有获取被增强的方法相关信息 如String test.component.test1

  • SpringAOP切入点规范及获取方法参数的实现

    切入点规范 @Pointcut("execution(* com.example.server.service.TeacherService.*(..))") 上面的切入点会切入com.example.server.service.TeacherService下面的所有方法. 下面来详细介绍一下切入点表达式的规范. 1.execution():表达式主体. 2.第一个位置:表示返回类型, *号表示所有的类型. 3.第二个位置:表示需要拦截的包名.类名.方法名(方法参数). 需要注意的是

  • SpringAop切入点execution表达式的深入讲解

    目录 一.Aspect切入点语法定义 二.如何定义多个切入点,在多个表达式之间如何表示 三.execution表达式 五.方法签名表达式 六.其他替代的切入点指示符 七.通配符 总结 一.Aspect切入点语法定义 在使用spring框架配置AOP的时候,不管是通过XML配置文件形式,还是注解的方式都需要定义pointcut(切入点),pointcut称之为切入点. 例如 : 定义切入点表达式  : execution (* com.sample.service.impl..*.*(..)) 上

  • spring aop execution表达式的用法

    1.切所有controller下的请求 项目结构 任意公共方法的执行: execution(public * (-)) ##public可以省略, 第一个 代表方法的任意返回值 第二个参数代表任意包+类+方法 (-)任意参数 配置切入点: @Pointcut("execution(* com.gcol.qy.web.system.controller..*.*(..))") public void conPoint(){} 表达式结构解释如下: 标识符 含义 execution() 表

  • 详解Spring 框架中切入点 pointcut 表达式的常用写法

    自从使用 AspectJ 风格切面配置,使得 spring 的切面配置大大简化,但是 AspectJ 是另外一个开源项目,其规则表达式的语法也稍稍有些怪异. 下面给出一些常见示例的写法,例如,下面是一个对 Service 包上所有方法的切面配置: <aop:config> <aop:pointcut id="serviceOperation" expression="execution(* *..service*..*(..))"/> <

  • Java8语法糖之Lambda表达式的深入讲解

    一.Lambda表达式简介 Lambda表达式,是Java8的一个新特性,也是Java8中最值得学习的新特性之一.(另一个新特性是流式编程.) Lambda表达式,从本质上讲是一个匿名方法.可以使用这个匿名方法,实现接口中的方法. 功能:通常使用Lambda表达式,是为了简化接口实现的.关于接口实现可以有多种方式实现,例如:①设计接口的实现类.②使用匿名内部类.但是③使用lambda表达式,比这两种方式都简单. 要求:lambda表达式,只能实现函数式接口:即一个接口中,要求实现类必须实现的抽象

  • Spring基于XML实现Aop

    目录 项目结构 具体步骤 1.创建maven 项目 导入依赖 创建好项目结构 2.写一个TestDao接口 及实现类 3.编写切面类 测试 总结 项目结构 具体步骤 1.创建maven 项目 导入依赖 创建好项目结构 <dependencies> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version&g

  • Spring深入讲解实现AOP的三种方式

    [重点] 使用AOP织入 需要导入一个依赖包 <dependencies> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.9.9.1</version> </dependency> </dependencies> 方式一:使用原生Spring AP

  • SpringAOP 设置注入的实现步骤

    AOP_面向切面编程初步了解 让我们先想象一个场景,你正在编写一个项目,在开发过程中的多个模块都有某段重复的代码,于是你选择将其抽象成一个方法,然后在需要的地方调用这个方法,当需要修改这段代码时只需要修改这个方法就行.有一天,你的Boss给了新的需求,需要再抽象出一个方法,然后再在各个需要这个方法的模块调用这个方法,这可能就让你头疼了,需要修改大量的代码,于是会想,能不能不修改源代码为系统业务添加某种功能呢?幸运的是,AOP可以很好的解决这个问题. 简单介绍 AOP:保证开发者不修改源代码的前提

  • 如何在SpringBoot中使用Spring-AOP实现接口鉴权

    目录 面向切面编程 AOP的底层原理实现 AOP的相关术语 相关注解以及切入点表达式 实现接口鉴权 1. 配置yml文件 2. 读取账密配置 3.编写接口鉴权方法 4. 编写AOP 5.编写接口测试 面向切面编程 面向切面编程,可以将与业务无关但是需要被各个业务模块共同调用的逻辑抽取出来,以切面的方式切入到代码中,从而降低系统中代码的耦合度,减少重复的代码. Spring AOP是通过预编译方式和运行期间动态代理实现程序面向切面编程 AOP的底层原理实现 AOP底层使用动态代理完成需求,为需要增

  • SpringAOP如何获取方法参数上的注解

    SpringAOP获取方法参数上的注解 一.示例 ① 如下代码,自定义一个参数注解@Test,并将其使用到方法参数上,用于标注需要检验的参数 /** * 自定义注解,用于参数 */ @Target(PARAMETER) @Documented @Retention(RetentionPolicy.RUNTIME) public @interface Test{ } /** * 接口层,使用使用@Test注解标记参数 */ @RestController @RequestMapping("/v1/

随机推荐