定义需要切入的切入点
@Component
public class Chinese implements Person {
// 实现Person接口的sayHello()方法
public String sayHello(String name) {
System.out.println("sayHello方法被执行了");
// 返回简单的字符串
return name + " Hello , Spring AOP";
}
// 定义一个eat()方法
public void eat(String food) {
System.out.println("我正在吃:" + food);
}
定义切面用于”拦截“需要的切入的切入点
@Aspect
public class AfterReturningAdviceTest {
// 匹配org.crazyit.app.service.impl包下所有类的、
// 所有方法的执行作为切入点
@AfterReturning(returning = "rvt", pointcut = "execution(* org.crazyit.app.service.impl.*.*(..))")
public void log(Object rvt) {
System.out.println("获取目标方法返回值:" + rvt);
System.out.println("模拟记录日志功能...");
}
}
最后工作交给spring管理
<?xml version="1.0" encoding="GBK"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
<!-- 指定自动搜索Bean组件、自动搜索切面类 -->
<context:component-scan base-package="org.crazyit.app.service
,org.crazyit.app.advice">
<context:include-filter type="annotation"
expression="org.aspectj.lang.annotation.Aspect"/>
</context:component-scan>
<!-- 启动@AspectJ支持 -->
<aop:aspectj-autoproxy/>
</beans>
小小测试
public class BeanTest {
public static void main(String[] args) {
// 创建Spring容器
ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
Person p = (Person) ctx.getBean("chinese", Person.class);
System.out.println(p.sayHello("张三"));
p.eat("西瓜");
}
}