spring aop execution表达式的用法
更新时间:2021年07月17日 16:33:34 作者:小贼驴
这篇文章主要介绍了spring aop execution表达式的用法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
1.切所有controller下的请求
项目结构
任意公共方法的执行:
execution(public * (…))
##public可以省略, 第一个 代表方法的任意返回值 第二个参数代表任意包+类+方法 (…)任意参数
配置切入点:
@Pointcut("execution(* com.gcol.qy.web.system.controller..*.*(..))") public void conPoint(){}
表达式结构解释如下:
标识符 | 含义 |
---|---|
execution() | 表达式的主体 |
第一个“ * ”符号 | 表示返回值的类型任意 |
com.gcol.qy.web.system.controller | AOP所切的服务的包名,即,需要进行横切的业务类 |
包名后面的“..” | 表示当前包及子包 |
第二个“*” | 表示类名,*即所有类 |
.*(..) | 表示任何方法名,括号表示参数,两个点表示任何参数类型 |
如果需要多个切入点可以用 || 符号 如下:
@Pointcut("execution(* com.gcol.qy.web.system.controller..*.*(..)) || execution(* com.gcol.qy.web.system.api..*.*(..))") public void conPoint(){}
xml 配置
<!-- 切换到获取kpi信息的oracle数据库 --> <aop:config> <aop:aspect id="dataSourceAspect2" ref="dataSourceInterceptor"> <aop:pointcut id="daoThree" expression="execution(* com.gcol.qy.web.system.service.kpi.KpiServiceImpl.*(..)) || execution(* com.gcol.qy.web.system.service.team.TeamServiceImpl.getFamilyPremiun(..)) || execution(* com.gcol.qy.web.system.service.team.TeamServiceImpl.getSalesmanPremium(..))"/> <aop:before pointcut-ref="daoThree" method="setDataSourceKpi"/> </aop:aspect> </aop:config>
ref=“dataSourceInterceptor” 执行的方法类。
2.Spring中execution语法
语法格式
execution(修饰符 返回类型 切入点类 切入点方法(参数) 异常抛出)
- 修饰符: 可选,支持通配符,(public/private/protected)
- 返回类型: 必填,支持通配符,可以使用 * 来匹配所有的返回值类型
- 切入点类: 可选,支持通配符,指定切入点类
- 切入点方法: 必填,支持通配符,指定要匹配的方法名,可以使用"*"通配符来匹配所有方法
- 参数: 若无可不填,指定方法声明中的形参列表,支持两个通配符,即*和…
其中*代表一个任意类型的参数,而…代表零个或多个任意类型的参数
- () 匹配一个不接受任何参数的方法
- (…) 匹配一个接受任意数量参数的方法,可以是零个或多个
- (*) 匹配一个接受一个任何类型的参数的方法,只能是一个
- (*,String) 匹配一个接受两个参数的方法,其中第一个参数是任意类型,第二个参数必须是String类型
异常抛出: 可选,支持通配符,指定方法声明抛出的异常
常用实例
<!-- 【1、拦截所有public方法】 --> <aop:pointcut expression="execution(public * *(..))" id="pt"/> <!-- 【2、拦截所有save开头的方法】 --> <aop:pointcut expression="execution(* save*(..))" id="pt"/> <!-- 【3、拦截指定类的指定方法, 拦截时候一定要定位到方法】 --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..))" id="pt"/> <!-- 【4、拦截指定类的所有方法】 --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.*(..))" id="pt"/> <!-- 【5、拦截指定包,以及其自包下所有类的所有方法】 --> <aop:pointcut expression="execution(* com..*.*(..))" id="pt"/> <!-- 【6、多条件】 --> <!-- 或:|| or --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) || execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) or execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <!-- 且:&& and --> <!-- 语法虽然没错,但,没意义 --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) && execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) and execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <!-- 【7、取非值:not ! 不拦截指定的规则,拦截除此之外的所有类的方法】 --> <aop:pointcut expression="!execution(* com.shore.dao.impl.UserDao.save(..))" id="pt"/> <!-- 注意not前必须有空格 --> <aop:pointcut expression=" not execution(* com.shore.dao.impl.UserDao.save(..))" id="pt"/>
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
springboot整合shardingjdbc实现分库分表最简单demo
我们知道分库分表是针对某些数据量持续大幅增长的表,比如用户表、订单表等,而不是一刀切将全部表都做分片,这篇文章主要介绍了springboot整合shardingjdbc实现分库分表最简单demo,需要的朋友可以参考下2021-06-06java 装饰模式(Decorator Pattern)详解
这篇文章主要介绍了java 装饰模式(Decorator Pattern)详解的相关资料,需要的朋友可以参考下2016-10-10
最新评论