AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,经过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。java
AOP是Spring框架中的一个重要内容,它经过对既有程序定义一个切入点,而后在其先后切入不一样的执行内容,好比常见的有:web
打开数据库链接/关闭数据库链接、打开事务/关闭事务、记录日志等。基于AOP不会破坏原来程序逻辑,所以它能够很好的对业务逻辑的各个部分进行隔离,spring
从而使得业务逻辑各部分之间的耦合度下降,提升程序的可重用性,同时提升了开发的效率。数据库
准备工做:编程
pom中引入:框架
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
* Spring Boot中使用AOP统一处理Web请求日志
* 使用@Aspect注解将一个java类定义为切面类
* 使用@Pointcut定义一个切入点,能够是一个规则表达式,好比下例中某个package下的全部函数,也能够是一个注解等。
* 根据须要在切入点不一样位置的切入内容
* 使用@Before在切入点开始处切入内容
* 使用@After在切入点结尾处切入内容
* 使用@AfterReturning在切入点return内容以后切入内容(能够用来对处理返回值作一些加工处理)
* 使用@Around在切入点先后切入内容,并本身控制什么时候执行切入点自身的内容
* 使用@AfterThrowing用来处理当切入内容部分抛出异常以后的处理逻辑函数
/***
* 在WebLogAspect切面中,分别经过doBefore和doAfterReturning两个独立函数实现了切点头部和
* 切点返回后执行的内容,若咱们想统计请求的处理时间,就须要在doBefore处记录时间,并在doAfterReturning
* 处经过当前时间与开始处记录的时间计算获得请求处理的消耗时间。
* 那么咱们是否能够在WebLogAspect切面中定义一个成员变量来给doBefore和doAfterReturning一块儿访问呢?
* 是否会有同步问题呢?
* 的确,直接在这里定义基本类型会有同步问题,因此咱们能够引入ThreadLocal对象
*/spring-boot
/***
* 优化:AOP切面的优先级
* 因为经过AOP实现,程序获得了很好的解耦,可是也会带来一些问题,好比:咱们可能会对Web层作多个切面,校验用户,校验头信息等等,这个时候常常会碰到切面的处理顺序问题。
* 因此,咱们须要定义每一个切面的优先级,咱们须要@Order(i)注解来标识切面的优先级。i的值越小,优先级越高。假设咱们还有一个切面是CheckNameAspect用来校验name必须为didi,
* 咱们为其设置@Order(10),而上文中WebLogAspect设置为@Order(5),因此WebLogAspect有更高的优先级,这个时候执行顺序是这样的:
* 在@Before中优先执行@Order(5)的内容,再执行@Order(10)的内容
* 在@After和@AfterReturning中优先执行@Order(10)的内容,再执行@Order(5)的内容
* 因此咱们能够这样子总结:
* 在切入点前的操做,按order的值由小到大执行
* 在切入点后的操做,按order的值由大到小执行
*/优化