一,根據上篇博客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的到的結果