基于Annotation的Spring AOP: @AfterReturning

AfterReturning 增强处理将在目标方法正常完成后被织入。

使用@AfterReturning可指定如下两个属性:

① pointcut / value : 两者都用于指定该切入点对应的切入表达式

returning : 指定一个返回值形参名,增强处理定义的方法可通过该行参名来访问目标方法的返回值。

基于Annotation的Spring AOP: @AfterReturning_第1张图片

Person.java :

public interface Person {
	public String sayHello(String name);
	public void eat(String food);
}
Chinese.java :

import org.springframework.stereotype.Component;

@Component
public class Chinese implements Person {

	@Override
	public void eat(String food) {
		System.out.println("我正在吃:"+food);
	}

	@Override
	public String sayHello(String name) {
		System.out.println("sayHello方法被执行了");
		return name+"Hello,Spring AOP";
	}

}
AfterReturningAdviceTest.java :

import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;

/**
 * 定义一个切面
 * @author Administrator
 *
 */
@Aspect
public class AfterReturningAdviceTest {
	
	@AfterReturning(returning="rvt",pointcut="execution(* com.bean.*.*(..))")
	public void log(Object rvt){
		System.out.println("获取目标方法返回值:"+rvt);
		System.out.println("模拟记录日志的功能...");
	}
	
}
bean.xml :



    
    
    
        
    
    
   
    
 
Test.java :

public class Test {
	public static void main(String[] args) {
		
		ApplicationContext ctx=new ClassPathXmlApplicationContext("bean.xml");
		Person p=(Person) ctx.getBean("chinese");
		System.out.println(p.sayHello("张三"));
		p.eat("西瓜");
	}
}
运行控制台输出:

基于Annotation的Spring AOP: @AfterReturning_第2张图片


你可能感兴趣的:(Spring)