Spring Boot教程(六)使用AOP统一处理Web请求日志

AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,经过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是Spring框架中的一个重要内容,它经过对既有程序定义一个切入点,而后在其先后切入不一样的执行内容,好比常见的有:打开数据库链接/关闭数据库链接、打开事务/关闭事务、记录日志等。基于AOP不会破坏原来程序逻辑,所以它能够很好的对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度下降,提升程序的可重用性,同时提升了开发的效率。html

下面主要讲两个内容,一个是如何在Spring Boot中引入Aop功能,二是如何使用Aop作切面去统一处理Web请求的日志。git

如下全部操做基于chapter4-2-2工程进行。web

准备工做

由于须要对web请求作切面来记录日志,因此先引入web模块,并建立一个简单的hello请求的处理。spring

  • pom.xml中引入web模块
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

     

  • 实现一个简单请求处理:经过传入name参数,返回“hello xxx”的功能。
    @RestController
    public class HelloController {
    
        @RequestMapping(value = "/hello", method = RequestMethod.GET)
        @ResponseBody
        public String hello(@RequestParam String name) {
            return "Hello " + name;
        }
    
    }

    下面,咱们能够对上面的/hello请求,进行切面日志记录。数据库

    引入AOP依赖

    在Spring Boot中引入AOP就跟引入其余模块同样,很是简单,只须要在pom.xml中加入以下依赖:编程

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-aop</artifactId>
    </dependency>

    在完成了引入AOP依赖包后,通常来讲并不须要去作其余配置。也许在Spring中使用过注解配置方式的人会问是否须要在程序主类中增长@EnableAspectJAutoProxy来启用,实际并不须要。app

    能够看下面关于AOP的默认配置属性,其中spring.aop.auto属性默认是开启的,也就是说只要引入了AOP依赖后,默认已经增长了@EnableAspectJAutoProxy框架

    # AOP
    spring.aop.auto=true # Add @EnableAspectJAutoProxy.
    spring.aop.proxy-target-class=false # Whether subclass-based (CGLIB) proxies are to be created (true) as
     opposed to standard Java interface-based proxies (false).

    而当咱们须要使用CGLIB来实现AOP的时候,须要配置spring.aop.proxy-target-class=true,否则默认使用的是标准Java的实现。spring-boot

  • 源码来源spa

相关文章
相关标签/搜索