spring4 AOP 面向切面编程@Aspect

AOP(Aspect-Oriented Programming, 面向切面编程): 是一种新的方法论, 是对传统 OOP(Object-Oriented Programming, 面向对象编程) 的补充.

AOP 的好处:

---每个事物逻辑位于一个位置, 代码不分散, 便于维护和升级

---业务模块更简洁, 只包含核心业务代码.

切面(Aspect): 横切关注点(跨越应用程序多个模块的功能)被模块化的特殊对象

通知(Advice): 切面必须要完成的工作

目标(Target): 被通知的对象

代理(Proxy): 向目标对象应用通知之后创建的对象

连接点(Joinpoint):程序执行的某个特定位置:如类某个方法调用前、调用后、方法抛出异常后等。连接点由两个信息确定:方法表示的程序执行点;相对点表示的方位。例如 ArithmethicCalculator#add() 方法执行前的连接点,执行点为 ArithmethicCalculator#add(); 方位为该方法执行前的位置

切点(pointcut):每个类都拥有多个连接点:例如 ArithmethicCalculator 的所有方法实际上都是连接点,即连接点是程序类中客观存在的事务。AOP 通过切点定位到特定的连接点。类比:连接点相当于数据库中的记录,切点相当于查询条件。切点和连接点不是一对一的关系,一个切点匹配多个连接点,切点通过 org.springframework.aop.Pointcut 接口进行描述,它使用类和方法作为连接点的查询条件。

<!-- AOP 面向切面编程 : 注解 -->
 <aop:aspectj-autoproxy></aop:aspectj-autoproxy>

package cn.util;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.stereotype.Component;

/**
 * spring4 AOP 面向切面编程(注解)
 * @author
 *
 */
@Component
public class AOPTest {
 
 public int sum(int x,int y){
  int sum= x + y;
  System.out.println("2.方法体: sum=" + sum);
  return sum;
 }

 public int sum2(Integer x, Integer y){
  return x+y;
 }
 
 public static void main(String args[]){
  
  ApplicationContext app = new ClassPathXmlApplicationContext("applicationContext.xml");
  AOPTest test = (AOPTest)app.getBean(AOPTest.class);
  int sum=test.sum(8, 9);
  
  
 }
}

package cn.util;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.stereotype.Component;

/**日志切面*/
@Component
@Aspect
public class AOPTestAspect {
 
 /**使用JoinPoint 获取 sum(int , int) 参数值*/
 @Before("execution(public int cn.util.AOPTest.sum(int , int ))")
 public void before(JoinPoint point){
  String methodName = point.getSignature().getName();
  Object[] args = point.getArgs();
  System.out.println("1.方法执行前:x=" + args[0] + "  y="+args[1] + " method: "+ methodName);
 }
 
 @After("execution(public int cn.util.AOPTest.sum(int , int ))")
 public void after(){
  System.out.println("3.方法执行后:");
 }

}

猜你喜欢

转载自zw7534313.iteye.com/blog/2221200
今日推荐