一步一步学习spring(六)——注解方式实现AOP的例子
刚看了下spring AOP,先停下来整理下知识。
下面主要描述spring中使用AOP的两个例子:一个采用注解的方式来实现,另一个采用声
明的方式来实现。描述这两个例子有两个目的:一是熟悉spring中的AOP使用,二就是以这些
例子作为以后对spring AOP分析作铺垫。废话少说,首先复兴下AOP种一些比较重要的概念:
Joinpoint(连接点):程序执行时的某个特定的点,在Spring中就是某一个方法的执行
Pointcut(切点):说的通俗点,spring中AOP的切点就是指一些方法的集合,而这些方法
是需要被增强、被代理的。一般都是按照一定的约定规则来表示的,如正则表达式等。切点是
由一类连接点组成。
Advice(通知):还是说的通俗点,就是在指定切点上要干些什么。
Advisor(通知器):其实就是切点和通知的结合
好了,概念就不多说了,如果要了解详细点,可以google一把,现在先描述出两个例子中
的一个,其中一个是采用注解的方式来实行切面编程,具体如下:
首先,在spring配置文件中加入如下配置(用来申明spring对@AspectJ的支持):
<aop:aspectj-autoproxy/>
如果你使用的是DTD,可以在Spring配置文件中加入如下配置来申明spring对@Aspect的支
持:
<bean />
编写目标对象类(CommonEmployee.java),具体代码如下(省略接口类):
编写测试类Test.java,具体如下:
package com;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import com.aop.Employee;public class Test {public static void main(String[] args) throws Exception{ ApplicationContext act = new ClassPathXmlApplicationContext("applicationContext-aop.xml"); Employee e = (Employee)act.getBean("employee"); e.signIn();}}
测试得出结果为:logBefore:现在时间是:Thu Apr 01 16:34:27 CST 2010
logAround开始:现在时间是:Thu Apr 01 16:34:27 CST 2010
good已经签到了...........
logAfter:现在时间是:Thu Apr 01 16:34:27 CST 2010
logAround结束:现在时间是:Thu Apr 01 16:34:27 CST 2010
一些注意的知识:
1.环绕方法通知,环绕方法通知要注意必须给出调用之后的返回值,否
则被代理的方法会停止调用并返回null,除非你真的打算这么做。
2.只有环绕通知才可以使用JoinPoint的子类ProceedingJoinPoint,个
连接点类型可以调用代理的方法,并获取、改变返回值。
一下子就写了这么多了,那声明风格的AOP还是在下篇描述了,看了看资料,还声明风格的AOP内容还是比较多的