<aop:config>
<aop:pointcut id="loggerCutpoint"
expression = "execution(* com.how2java.service.ProductService.*(..)) "/>
<aop:aspect id="logAspect" ref="loggerAspect">
<aop:around pointcut-ref="loggerCutpoint" method="log"/>
</aop:aspect>
</aop:config>
这个配置过程是什么含义呢?
<aop:pointcut id="loggerCutpoint" expression="execution(* com.how2java.service.ProductService.*(..)) "/>
这一句是声明切入点,切入点的 id 叫 loggerCutPoint ,用来标记这个切入点。
这个expression表示:满足expression中的方法调用之后,就会去进行切面操作,类似于触发了切面:
第一个 * 代表返回任意类型
com.how2java.service.ProductService.* 表示包名以 com.how2java.service.ProductService 开头的类的任意方法(第二个*表示任意方法,通配符肯定知道吧)
(..) 表示方法的参数是任意数量和类型
简单说就是,只要com.how2java.service这个包中的ProductService类的任意一个函数被调用,不管你的返回值是什么,都会触发开关,我就会去执行切面,也就是辅助功能,但是辅助功能是什么呢,就是下面两句:
<aop:aspect id="logAspect" ref="loggerAspect">
<aop:after pointcut-ref="loggerCutpoint" method="log"/>
</aop:aspect>
这两句是定义了一个切面,上面说只要触发开关,就会去执行切面,就是指的这里的切面,所谓切面,就是一个类中的方法而已。
id代表这个切面的名字,ref指方法所在的类,method代表的就是方法的名字,
pointcut-ref="loggerCutpoint" 这个就是表示我这个切面是和上面的切点关联起来的(一个切点是可以关联多个切面的,一个切面只能关联一个方法),只要上面的切点被触发,我就会到这里来执行一些辅助功能。
after表示在切入点触发之后来执行我这个中断,当然也有before,一共有五个before,after,After-returning ,After-throwing,Around。
在 method 参数后面,还可以加上参数列表。