本文介绍SpringBoot中使用Spring AOP。

简介

AOP简介

AOP可能对于广大开发者耳熟能详,它是Aspect Oriented Programming的缩写,翻译成中文就是:面向切面编程。这个可能是面试中经常提到的问题,同时它也是Spring框架中一个重大的特性,AOP主要实现的目的是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果,对于我们开发中最常见的可能就是日志记录,事务处理,异常处理等等。

SpringBoot中使用AOP

接下来介绍SpringBoot项目中如何运用AOP。

新建项目

新建一个SpringBoot项目,在pom文件中加入AOP依赖,完整代码如下:

<?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.dalaoyang</groupId><artifactId>springboot_aop</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>springboot_aop</name><description>springboot_aop</description><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.4.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
复制代码

创建切面

一 直接使用切面

新建一个日志切面类,假设我们需要一个类来打印进入方法或方法执行后需要打印的日志。

新建一个切面类

新建类LogAspect,完整代码如下:

package com.dalaoyang.aspect;import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.springframework.stereotype.Component;
import org.aspectj.lang.annotation.*;@Aspect
@Component
public class LogAspect {@Pointcut("execution(public * com.dalaoyang.controller.*.*(..))")public void LogAspect(){}@Before("LogAspect()")public void doBefore(JoinPoint joinPoint){System.out.println("doBefore");}@After("LogAspect()")public void doAfter(JoinPoint joinPoint){System.out.println("doAfter");}@AfterReturning("LogAspect()")public void doAfterReturning(JoinPoint joinPoint){System.out.println("doAfterReturning");}@AfterThrowing("LogAspect()")public void deAfterThrowing(JoinPoint joinPoint){System.out.println("deAfterThrowing");}@Around("LogAspect()")public Object deAround(ProceedingJoinPoint joinPoint) throws Throwable{System.out.println("deAround");return joinPoint.proceed();}}复制代码

其中:

  • @Aspect 表明是一个切面类
  • @Component 将当前类注入到Spring容器内
  • @Pointcut 切入点,其中execution用于使用切面的连接点。使用方法:execution(方法修饰符(可选) 返回类型 方法名 参数 异常模式(可选)) ,可以使用通配符匹配字符,*可以匹配任意字符。
  • @Before 在方法前执行
  • @After 在方法后执行
  • @AfterReturning 在方法执行后返回一个结果后执行
  • @AfterThrowing 在方法执行过程中抛出异常的时候执行
  • @Around 环绕通知,就是可以在执行前后都使用,这个方法参数必须为ProceedingJoinPoint,proceed()方法就是被切面的方法,上面四个方法可以使用JoinPoint,JoinPoint包含了类名,被切面的方法名,参数等信息。

二 利用自定义注解使用AOP

新建自定义注解

新建自定义注解,新建注解与新建接口类似,将interface改为@interface即可。

package com.dalaoyang.annotation;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface DoneTime {String param() default "";
}复制代码

创建自定义注解对应切面

创建自定义注解对应切面,与上一中情况的切面类似,这里就不在赘述了,代码如下:

package com.dalaoyang.aspect;import com.dalaoyang.annotation.DoneTime;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;import java.util.Date;@Aspect
@Component
public class DoneTimeAspect {@Around("@annotation(doneTime)")public Object around(ProceedingJoinPoint joinPoint, DoneTime doneTime) throws Throwable {System.out.println("方法开始时间是:"+new Date());Object o = joinPoint.proceed();System.out.println("方法结束时间是:"+new Date()) ;return o;}
}复制代码

创建Controller测试

创建一个IndexController进行测试,其实就是两个普通的Web请求方法,其中index使用了自定义注解,index2没有使用自定义注解,完整代码如下:

package com.dalaoyang.controller;import com.dalaoyang.annotation.DoneTime;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class IndexController {@GetMapping("/index")@DoneTime(param = "IndexController")public String index(){System.out.println("方法执行");return "hello dalaoyang";}@GetMapping("/index2")public String index2(){System.out.println("方法2执行");return "hello dalaoyang";}
}
复制代码

运行测试

启动项目,在浏览器访问http://localhost:8080/index,控制台如下:

在浏览器访问http://localhost:8080/index2,控制台如下:

总结

本文只是简单介绍一下SpringBoot使用Spring AOP,当然它可能还有其他使用方法,具体的情况需要根据我们实际情况来使用。

源码下载 :大老杨码云

SpringBoot使用AOP相关推荐

  1. aop springboot 传入参数_java相关:springboot配置aop切面日志打印过程解析

    java相关:springboot配置aop切面日志打印过程解析 发布于 2020-3-31| 复制链接 摘记: 这篇文章主要介绍了springboot配置aop切面日志打印过程解析,文中通过示例代码 ...

  2. java 切面 不执行,解决springboot的aop切面不起作用问题(失效的排查)

    检查下springboot的启动类是否开启扫描 @springbootapplication @componentscan(basepackages = {"com.zhangpu.spri ...

  3. SpringBoot的AOP是默认开启的,不需要加注解@EnableAspectJAutoProxy____听说SpringAOP 有坑?那就来踩一踩

    @Aspect @Component public class CustomerServiceInterceptor {@Before("execution(public * org.exa ...

  4. SpringBoot使用AOP,PointCut表达式详解以及使用

    SpringBoot使用AOP,PointCut表达式详解以及使用 1.相关注解 2.PointCut 表达式详解 2.1 execution: 2.1 within: 2.3. this: 2.4. ...

  5. SpringBoot利用Aop打印入参出参日志

    SpringBoot利用Aop打印入参出参日志 前言 以前写代码不会用Aop的时候,记录入参出参的日志打印都是在Controller中完成的,每个Controller的方法开始之前先打印个日志,然后方 ...

  6. 基于SpringBoot的AOP记录日志

    基于SpringBoot的AOP记录日志 package com.pgeneral.dlabs.sop.aop;import java.lang.annotation.*;/*** @author Y ...

  7. SpringBoot之AOP面向切面编程

    什么是AOP AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期间动态代理实现程序功能的统一维护的一种技术.AOP是OOP的延续,是软件开 ...

  8. springboot之aop切面获取请求

    springboot之aop切面获取请求 项目场景: 在学习springboot的博客开发中,通过aop切面,对博客中的操作进行记录 问题描述: 问题: 在切面方法中,无法获取请求的参数和类名,方法, ...

  9. SpringBoot之AOP面向切面编程实例

    目录 1.引入pom依赖 2.切入点表达式 --组成 --逻辑运算符 --通配符 --范例 3. 启动类配置 4.通知类型 4.1 @Before : 标注当前方法作为前置通知 4.1.1 创建自定义 ...

  10. SpringBoot通过AOP实现系统日志记录(一)-Controller层日志监控

    Service层日志监控:SpringBoot通过AOP实现系统日志记录(二)-Service层日志监控 Mapper层日志监控:SpringBoot通过AOP实现系统日志记录(三)-Mapper层日 ...

最新文章

  1. Nginx(一)------简介与安装
  2. Android之给图片去色,返回灰度图片以及ColorMatrix中setSaturation方法的用法
  3. Hadoop集群的kerberos认证
  4. 让你的echo带颜色
  5. Linux IPC udp/ip socket 编程
  6. 电脑麦克风,详细教你电脑麦克风没声音怎么设置
  7. 支付宝 客户端 Android 集成流程
  8. 大数据比赛笔记(一)基本环境配置
  9. Vivado使用系列:使用自定义BD
  10. 埃及分数数学模型c语言,C语言将真分数分解为埃及分数代码解析
  11. 机器学习-决策树算法
  12. Spring漫画学习笔记(一) 什么是BeanDefinition
  13. VS2015编辑图片
  14. NOIP 2018 提高组初赛试题 题目+答案+简要解析
  15. N诺刷题——字符串、排序、查找、链表
  16. 苹果画画软件_Mac必装的10个软件,让你的Mac如虎添翼
  17. 基于微信小程序的RSS订阅器
  18. 手游行业2011年十大事件盘点
  19. Win10电脑定时关机怎么设置?(干货)
  20. Window打开服务的DOS命令

热门文章

  1. 怎样从tensorflow的generator object Estimator.predict at 0x7fb1ecefeaf0中取数据
  2. 【pytorch】torch.mean的使用
  3. b temia 外骨骼机器人_只能提高工作效率?现代外骨骼正在突破重重壁垒,走向融合的未来...
  4. html阅读开放试用阶段,泰克为不同行业提供100种应用功能免费试用
  5. dataset的去重计数 g2_去互联网公司面试,面试官问我SpringCloud,附答案
  6. Docker(八):Docker Compose
  7. MySQL慢查询日志分析(二)
  8. @AUTORELEASEPOOL
  9. @available 和 #available
  10. 软件测试技术之功能测试六要素