本篇内容主要讲解“spring aop execution表达式的用法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“spring aop execution表达式的用法是什么”吧!
项目结构
任意公共方法的执行:
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” 执行的方法类。
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"/>
到此,相信大家对“spring aop execution表达式的用法是什么”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。