java之springboot的spring-boot-starter-aop的切面編程的使用(四)


一,根據上篇博客java之springboot的swagger-spring-boot-starter的swagger的使用(三)的基礎上,我們添加AOP切面編程,我們先看看pom.xml要引入什么包

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.nl.testmybatis</groupId>
    <artifactId>testmybatis</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.7.RELEASE</version>
    </parent>

    <dependencies>
        <!--springframework.boot-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--這個mysql驅動-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.20</version>
        </dependency>
        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.3</version>
        </dependency>
        <!-- swagger-國人封裝的swagger -->
        <dependency>
            <groupId>com.spring4all</groupId>
            <artifactId>swagger-spring-boot-starter</artifactId>
            <version>1.9.0.RELEASE</version>
        </dependency>
        <!--aop切面編程-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
            <version>2.2.7.RELEASE</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <!--在使用mybatis時我們需要重復的去創建pojo類、mapper文件以及dao類並且需要配置它們之間的依賴關系,
            比較麻煩且做了大量的重復工作,mybatis官方也發現了這個問題,
            因此給我們提供了mybatis generator工具來幫我們自動創建pojo類、
            mapper文件以及dao類並且會幫我們配置好它們的依賴關系。
            -->
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <configuration>
                    <configurationFile>${project.basedir}/src/main/resources/generatorConfig.xml</configurationFile>
                    <overwrite>true</overwrite>
                </configuration>
                <dependencies>
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>8.0.20</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>
</project>

是這個包添加的

 

 二,我們編寫切面編程的類

package com.nl.testmybatis.aoptest;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component;

/*作用是把當前類標識為一個切面供容器讀取*/
@Aspect
@Component
public class AopAdvice {

    /*針對所有控制器的方法添加aop
    * 1,* com.nl.demo.controllers.*.*(..))解析
    * 2,第一個*是返回任意類型
    * 3,com.nl.demo.controllers是包路徑,針對所有的控制器
    * 4,第二個*是任意類
    * 5,第三個*是任意方法
    * 6,(..)的任意參數
    * */
   /* @Pointcut("execution (* com.nl.demo.controllers.*.*(..))")*/

    /*針對特定控制器,AopTestController的特定方法,*/
    @Pointcut("execution (* com.nl.testmybatis.controllers.AopTestController.sayHello(..))")
    public void test() {

    }

    /*標識一個前置增強方法,相當於BeforeAdvice的功能*/
    @Before("test()")
    public void beforeAdvice() {
        System.out.println("beforeAdvice...");
    }

    /*final增強,不管是拋出異常或者正常退出都會執行*/
    @After("test()")
    public void afterAdvice() {
        System.out.println("afterAdvice...");
    }

    /*環繞增強,相當於MethodInterceptor*/
    @Around("test()")
    public void aroundAdvice(ProceedingJoinPoint proceedingJoinPoint) {
        System.out.println("before");
        try {
            proceedingJoinPoint.proceed();
        } catch (Throwable t) {
            t.printStackTrace();
        }
        System.out.println("after");
    }

}

三,添加一個控制器,訪問測試AopTestController

package com.nl.testmybatis.controllers;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/*
*  使用@Aspect注解將此類定義為切面類
* */
@RestController
@RequestMapping("aopTest")
public class AopTestController {
    /*
    * 使用了aop
    * */
    @GetMapping("/hello")
    public String sayHello(){
        System.out.println("hello");
        return "hello";
    }
    /*
    * 不使用aop
    * */
    @GetMapping("/sayHelloTwo")
    public String sayHelloTwo(){
        System.out.println("sayHelloTwo");
        return "sayHelloTwo";
    }
}

四,最終項目結構如下

 

 

 五,我們通過swagger,訪問查看結果,訪問hello的到的結果

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM