Spring AOP 用户可能会经常使用 execution pointcut designator。执行表达式的格式如 下:
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern) throws -pattern?) execution(修饰匹配(可选) 返回类型(必填) 声明类型(可选) 方法名称(参数匹配) 抛出异常类型(可选))
除了返回类型模式(上面代码片断中的ret-type- pattern),名字模式和参数模式以外,所有的部分都是可选的。 返回类型模式决定了方法的返回类型必须依次匹配一个连接点。 你会使用的最频繁的返 回类型模式是 *,它代表了匹配任意的返回类型。 一个全称限定的类型名将只会匹配返回给定类型的方法。名字模式匹配的是方法名。 你可以使用 * 通配 符作为所有或者部分命名模式。 参数模式稍微有点复杂:() 匹配了一个不接受任何参数的方法, 而 (..) 匹配了一个接受任意数量参数的方法(零或 者更多)。 模式 (*) 匹配了一个接受一个任何类型的参数的方法。 模式 (*,String) 匹配了一个接受两个参数的方法,第一个可以是任意类 型,第二个则必须是String类型。
对于 execution()可以使用&& || !等操作符将各个表达式组合起来,限制切入点
下面给出一些常见切入点表达式的例子。
任意公共方法的 执行:
execution(public * *(..))任何一个以“set”开始的方法的执行:
execution(* set* (..))AccountService 接口的任意方法的执行:
execution(* com.xyz.service.AccountServ定ice.* (..))定义在service包里的任意方法的执行:
execution(* com.xyz.service.*.* (..))定义在service包或者子包里的任意方法的执行:
execution(* com.xyz.service..*.* (..))在service包里的任意连接点(在Spring AOP中只是方法执行) :
within(com.xyz.service.*) 在service包或者子包里的任意连接点(在Spring AOP中只是方法执行) :
within(com.xyz.service..*) 实现了 AccountService 接口的代理对象的任意连接点(在Spring AOP中只是方法执行) :
this (com.xyz.service.AccountService) 'this' 在binding form中用的更多:- 请常见以下讨论通知的章节中关于如 何使得代理对象可以在通知体内访问到的部分。
实现 了 AccountService 接口的目标对象的任意连接点(在Spring AOP中只是方法执行) :
target(com.xyz.service.AccountService)'target' 在binding form中用的更多:- 请常见以下讨论通知的章节中关 于如何使得目标对象可以在通知体内访问到的部分。
任何一个只接受一个参数,且在运行时 传入的参数实现了 Serializable 接口的连接点 (在Spring AOP中只是方法执行)
args(java.io.Serializable)'args' 在binding form中用的更多:- 请常见以下讨论通知的章节中关于如 何使得方法参数可以在通知体内访问到的部分。
请注意在例子中给出的切入点不同 于 execution(* *(java.io.Serializable)): args只有在动态运行时候传入参数是可序列化的 (Serializable)才匹配,而execution 在传入参数的签名声明的类型实现了 Serializable 接口时候匹配。
有 一个 @Transactional 注解的目标对象中的任意连接点(在 Spring AOP中只是方法执行)
@target (org.springframework.transaction.annotation.Transactional) '@target' 也可以在binding form中使用:请常见以下讨论通知的章节中 关于如何使得annotation对象可以在通知体内访问到的部分。
任何一个目标对象 声明的类型有一个 @Transactional 注解的连接点(在 Spring AOP中只是方法执行)
@within (org.springframework.transaction.annotation.Transactional) '@within' 也可以在binding form中使用:- 请常见以下讨论通知的章节 中关于如何使得annotation对象可以在通知体内访问到的部分。
任何一个执行的 方法有一个 @Transactional annotation的连接 点(在Spring AOP中只是方法执行)
@annotation (org.springframework.transaction.annotation.Transactional) '@annotation' 也可以在binding form中使用:- 请常见以下讨论 通知的章节中关于如何使得annotation对象可以在通知体内访问到的部分。
任何 一个接受一个参数,并且传入的参数在运行时的类型实现了 @Classified annotation 的连接点(在Spring AOP中只是方法执行)
@args (com.xyz.security.Classified) '@args' 也可以在binding form中使用:- 请常见以下讨论通知的章节中关 于如何使得annotation对象可以在通知体内访问到的部分。
=================================================================================
一。使用零配置格式 spring 关于aop的配置文件格式
<aop:aspectj-autoproxy proxy-target-class="true" /> 要加上黑体字,如果不加上的话,会可能出现编译通不过去
指定自动搜索bean组件,自动搜索切面类
<context:component-scan base-package="com">
<context:include-filter type="annotation"
expression="org.aspectj.lang.annotation.Aspect"/>
</context:component-scan>
但是以上两个配置最好不要同时出现,否则导致执行两次切面类
java类
定义切入点
定义advice类