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的到的结果