Spring-aop-Before/After/Around/Advisor与Pointcut接口的代码示例

2024-06-13 13:08

本文主要是介绍Spring-aop-Before/After/Around/Advisor与Pointcut接口的代码示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Advisor:它是标注有@Before@After@Around注解的方法的抽象
Pointcut:无论这个Pointcut是接口,还是注解,它抽象的都是带有execution表达式的东西

下面有这样一段代码,我们可以说MyAspect这个类中
有2个Advisor,分别是aa和bb
有2个Pointcut,分别是* com.abc.*.*(..)* com.xx包.*.*(..)

@Configuration
@Aspect
@EnableAspectJAutoProxy
public class MyAspect {@Before("execution(* com.abc.*.*(..))")public void aa() {System.out.println("你叫什么名字?");}@Before("execution(* com.xx包.*.*(..))")public void bb() {System.out.println("你叫什么名字?");}
}

下面是使用效果

package study.ssm.temp;public class MyUser {public void sayName() {System.out.println("我叫二抱,它叫三抱");}public static void main(String[] args) {AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(MyUser.class, MyAspect.class);MyUser user = ctx.getBean(MyUser.class);user.sayName();}
}
package study.ssm.temp;@Aspect
@EnableAspectJAutoProxy
public class MyAspect {@Before("execution(* study..*.*(..))")public void aa() {System.out.println("你们叫什么名字呀?");}
}

@AfterReturning 打印返回值
有时候我们需要打印一个方法的返回值,那么可以使用该注解,方式如下

@Pointcut("execution(* com.abc.*.*(..))")
public void pointcutDeclaration() {// NOOP
}// 注意:returning的参数名必须和方法printLog里的参数名称一样,如果returning = "abc",那么printLog(Object abc)
@AfterReturning(value = "pointcutDeclaration()", returning = "returnValue")
public void printLog(Object returnValue) {log.info("返回值:{}", JSON.toJSONString(returnValue));
}

彩色打印,由于服务器上的日志太多了,如果字体能够醒目一些,那就太好了,你可以如下一波操作

String msg= "\33[34m" + "日志内容" + "\33[0m";
log.info("\33[32m参数:{}", msg);
// System.log.println("\33[32m"+"绿色的内容"+"\33[34m" + "其他颜色的内容" + "\33[0m");

这篇关于Spring-aop-Before/After/Around/Advisor与Pointcut接口的代码示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057385

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1