本文将 以一个简单的记录日志实例来继续AOP的学习,近一步加深对AOP的了解。
1、首先新建个web工程,将spring的所需的jar包加进去,再来看下接口,很简单就两个方法
public interface Print { public String print(String name); public String sleep(String name); }2、接下来是实现类
public class SystemPrint implements Print{ public String print(String name){ String result="hello " + name; System.out.println(result); return result; } public String sleep(String name){ String result=name+" is sleep now"; System.out.println(result); return result; } }3、下面是所要织入的代码,也就是我们要用来记录日志的
public class GetLog { public void getLog(ProceedingJoinPoint joinpoint) throws Throwable { String reslut = (String)joinpoint.proceed(); //这里是记录日志的 System.out.println("result==="+reslut); } }4、再来看spring配置文件
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jee="http://www.springframework.org/schema/jee" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.0.xsd"> <!--这个bean是作为切面 --> <bean id="log" class="spring3aop.GetLog"></bean> <!-- 注意这里:expression="execution(* spring3aop.*.print*(..))" 括号里面第一个*号代表返回值 接下来 spring3aop.*. 是你要切入的代码的大概路径,这里为什么用大概路径来形容呢 因为这里的意思是符合以spring3aop的路径都会作为选择的对象,也不详细介绍,查下就明白了, print*(..)是指 方法名以print开头的都符合,括号里面的 .. 表示参数是随意的都可以。 --> <aop:config> <aop:aspect ref="log"> <aop:pointcut id="printMethods" expression="execution(* spring3aop.*.print*(..))"/> <aop:after-returning method="getLog" pointcut-ref="printMethods" returning="retVal"/> </aop:aspect> </aop:config> <aop:config> <aop:aspect ref="log"> <aop:pointcut id="sleepMethods" expression="execution(* spring3aop.*.sle*(..))"/> <aop:after-returning method="getLog" pointcut-ref="sleepMethods" returning="retVal"/> </aop:aspect> </aop:config> <!--要织入代码的bean--> <bean id="print" class="spring3aop.SystemPrint"></bean> </beans>5、测试类:
public class Test { /** * @Description 方法实现功能描述 * @param args * void * @throws 抛出异常说明 */ public static void main(String[] args) { ApplicationContext act = new ClassPathXmlApplicationContext( "applicationContext20.xml"); Print t =(Print)act.getBean("print"); t.print("ding"); System.out.println("-----------------"); t.sleep("laoding"); } }运行这个类,得到如下结果: