3.spring的aop之@AfterReturning

定义需要切入的切入点

@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("西瓜");
	}
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值