Spring AOP.
AOP: 面向切面编程 在不影响核心代码的前提下,可以在任意位置添加非核心代码。
举例:可以使用spring 的aop来完成代理日志
(1) 把相关spring的依赖加入
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.9.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.9.RELEASE</version>
</dependency>
<!--切面依赖-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>5.2.9.RELEASE</version>
</dependency>
</dependencies>
(2)创建一个切面类
package com.ykq.aop.after;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.Arrays;
/**
* 日志切面类
*/
@Component
@Aspect //表示该类为切面类 -----> 删除某一个记录 添加日志。 操作日志
public class LogAspect {
@Before(value = "execution(权限名 包路径.方法名(指定参数))") //service
public void before(JoinPoint joinPoint){
String name = joinPoint.getSignature().getName();
Object[] args = joinPoint.getArgs();
System.out.println("AAA--->The "+name+" method begin with "+ Arrays.asList(args));
}
//后置通知 finally
@After(value = "execution(* com.*.aop.after.*.*(..))")
public void after(JoinPoint joinPoint){
System.out.println("该方法总会被执行");
}
//后置返回通知 他可以得到返回结果r。
@AfterReturning(value = "execution(* com.*.aop.after.*.*(..))",returning = "r")
public void afterReturning(JoinPoint joinPoint,int r){
String name = joinPoint.getSignature().getName();
System.out.println("BBB--->The "+name+" method ends: "+r);
}
//异常通知 只有发生异常时才会被执行。
@AfterThrowing(value = "execution(* com.*.aop.after.*.*(..))",throwing = "e")
public void afterThrowing(Exception e){
System.out.println(e.getMessage());
}
}
(3) 配置文件开启切面注解
<?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:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd">
<!--包扫描-->
<context:component-scan base-package="com.ykq.aop.after"/>
<!--开启切面注解-->
<mvc:aspectj-autoproxy />
</beans>