为什么现在 Spring Boot 默认使用 CGLIB 了?

从 Spring Boot 2.0 开始,默认的代理方式被改为了 CGLIB (spring.aop.proxy-target-class=true)。

这是因为 CGLIB 解决了一个使用 JDK 代理时非常棘手的痛点:代理对象内部方法调用无法触发 AOP 的问题。

  • 场景:假设你有一个 UserServiceImpl 对象被 JDK 代理了。你在它的 methodA() 方法内部调用了同一个类中的 methodB() 方法(通过 this.methodB())。
  • 问题:这个 methodB() 的调用不会被 AOP 拦截!因为 this 指向的是原始的 UserServiceImpl 对象,而不是代理对象。这次调用是从对象内部发起的,绕过了代理。
  • CGLIB 的优势:使用 CGLIB 时,代理对象是原始对象的子类。在子类实例中,this 指向的就是代理对象本身。因此,内部调用 this.methodB() 依然是通过代理发起的,AOP 能够正常生效。

为了解决这种令人困惑的场景,提供更一致、更可预测的行为,Spring Boot 最终决定拥抱 CGLIB 作为默认选项。

相关推荐
踏雪羽翼4 小时前
android 解决混淆导致AGPBI: {“kind“:“error“,“text“:“Type a.a is defined multiple times
android·java·开发语言·混淆·混淆打包出现a.a
lang201509284 小时前
Tomcat Maven插件:部署与卸载的架构设计
java·tomcat·maven
一切尽在,你来5 小时前
C++ 零基础教程 - 第 5 讲 变量和数据类型
开发语言·c++
serve the people5 小时前
python环境搭建 (六) Makefile 简单使用方法
java·服务器·python
重生之后端学习5 小时前
146. LRU 缓存
java·数据结构·算法·leetcode·职场和发展
萧曵 丶5 小时前
懒加载单例模式中DCL方式和原理解析
java·开发语言·单例模式·dcl
℡枫叶℡5 小时前
C# - 指定友元程序集
开发语言·c#·友元程序集
回忆是昨天里的海5 小时前
k8s部署的微服务动态扩容
java·运维·kubernetes
萧曵 丶5 小时前
单例模式 7 种实现方式对比表
java·单例模式
阿猿收手吧!5 小时前
【C++】constexpr动态内存与双模式革命
开发语言·c++