32 KiB
深入Spring,从源码开始!
探索Java最受欢迎的框架,理解它的内部机制,带大家从入门到精通。
⚡ 技术 | 👋 简介 | 🍵 Why | 🙏 点个星 | 🌱 Spring源码 | 💬 联系我 | ⛵ 贡献 | 🔄 更新 | 💻 统计
⚡技术
👋简介
大家好呀,我是Lex👨💻。我是一名拥有8年经验的Java 后端开发人员👨💼,也是一个对 Spring 框架充满热情❤️的程序员。为了帮助那些希望深入了解 Spring 框架的程序员们🧑💻,我创建了这个 “Spring 源码阅读系列”📖。通过这个系列,我希望能够与你们共同探索 Spring 的内部工作机制⚙️。如果您有同样的兴趣或问题🤔,请联系我📩!
🍵为何做Spring源码分析
在我作为框架研发的开发者👨🔬的工作中,我经常遇到需要深入理解和调整框架行为的情况🔧。这些工作不只是简单地使用框架的API,更多地是需要对框架的内部工作方式有详细的了解🔍。虽然Github上有关于Spring的简化版本📦,这些对于入门学习确实有很大的帮助✅,但当涉及到真实的项目应用时,与真正的Spring框架还是有很大的差异❌。因此,我开始深入研究Spring的源码,希望能够更透彻地理解其内部的工作机制,以便更好地应用到我的实际工作中🧰。分享我的源码分析📝,也是为了给那些希望真正理解Spring,而不仅仅是使用它的开发者提供一些参考和帮助🙌。
🙏顺手点个星
亲爱的朋友们👥,我真的花了很多心思💭去研究和整理这个“Spring 源码阅读系列”📘。如果你觉得这东西还不错👍,或者给你带来了一点点帮助🤗,麻烦点一下星星吧🌟。这真的对我意义重大🎖,每一颗星✨都能让我觉得所有的努力都是值得的💪。我知道这是小事一桩,但你的那一下点击🖱,对我来说就是最好的鼓励🎉。无论如何,都要感谢你抽时间🕰阅读我的内容,真的很感激🙏!
🌱Spring 源码阅读系列
-
Spring Core
-
资源加载与访问
- Resource:抽象接口,表示文件、类路径等,用于访问不同来源的资源。
- ResourceLoader:资源获取核心接口,实现统一加载不同位置资源的策略。
- ResourcePatternResolver:资源模式解析接口,用于灵活加载应用中的多种资源。
- DocumentLoader:XML文档加载解析核心接口,支持后台自动配置Spring应用。
-
元数据与过滤
- MetadataReader:类元数据获取核心,支持组件扫描、条件化注解、AOP等高级功能。
- AnnotationMetadata:动态获取和操作运行时类注解信息。
- TypeFilter:组件扫描时自定义类筛选,支持复杂条件和精确过滤。
- Condition:条件判断,决定Bean创建和配置的灵活机制。
-
验证、数据绑定和类型转换
- Validator:提供自定义数据验证逻辑,确保模型对象满足业务规则。
- PropertyEditor:自定义JavaBean属性的转换逻辑,处理属性类型转换。
- Converter:用于不同类型间的转换,定义简单的源至目标类型转换规则。
- ConverterFactory:创建针对特定源类型的转换器,用于类型转换。
- GenericConverter:更复杂的转换器,支持多种源和目标类型转换。
- ConditionalConverter:根据条件选择是否执行转换的转换器。
- ConversionService:提供统一的类型转换服务接口,管理转换器。
- Printer:用于将对象格式化为文本,专注于格式化输出。
- Parser:用于将文本解析为对象,专注于解析逻辑。
-
Spring 表达式语言(SpEL)
- ExpressionParser: 解析字符串形式的 SpEL 表达式,创建并返回 Expression 实例。
- Expression: 对表达式字符串进行求值的功能,支持类型转换、获取原始字符串等操作。
- EvaluationContext: 管理SpEL表达式的上下文信息。
- PropertyAccessor: 用于读取和写入对象的属性,可用于实现自定义的属性访问逻辑。
- ConstructorResolver: 解析构造函数确定bean的实例化方式。
- MethodResolver: 解析类方法,确保正确调用,处理重载和参数匹配。
- BeanResolver: 解析bean定义,包括依赖、属性设置,实例化并返回。
- TypeLocator: 动态查找类,返回Class对象,在表达式解析、类型转换等。
- TypeConverter: 类型转换功能,将表达式中的数据从一种类型转换为另一种类型。
- TypeComparator: 类型比较功能,定义了比较两个对象是否相等的方法。
- OperatorOverloader: 运算符重载功能,对表达式中的运算符进行自定义操作的方法。
-
Bean定义与注册
- BeanDefinition:详细描述Bean,支持依赖注入、AOP、作用域控制等核心功能。
- BeanDefinitionHolder:管理和操作BeanDefinition的关键类。
- BeanDefinitionRegistry:Bean定义注册管理关键接口,处理Bean元数据。
-
Bean定义读取与扫描
- XmlBeanDefinitionReader:加载解析XML配置,构建IOC容器,注册Bean定义。
- PropertiesBeanDefinitionReader:属性文件加载,解析为Bean定义。
- GroovyBeanDefinitionReader:Groovy脚本解析为Bean定义。
- AnnotatedBeanDefinitionReader:注解配置,自动扫描注册Spring组件,简化Bean定义配置。
- ClassPathBeanDefinitionScanner:类路径扫描注册Spring Bean,支持自动装配。
-
Bean工厂
- BeanFactory:Spring的核心接口,提供对Bean的配置、创建、管理的基本功能。
- ListableBeanFactory:支持按类型获取Bean的集合。
- HierarchicalBeanFactory:支持父子容器关系,实现Bean定义的层次结构。
- ConfigurableBeanFactory:提供对BeanFactory配置的扩展,如属性编辑器、作用域等。
- AutowireCapableBeanFactory:Bean创建、初始化、注入、销毁的核心功能接口。
- ConfigurableListableBeanFactory:支持配置和列表操作的可配置Bean工厂接口。
-
容器上下文
- ClassPathXmlApplicationContext:类路径(classpath)加载 XML 配置文件的上下文。
- AnnotationConfigApplicationContext:注解配置类中加载配置信息的上下文。
- GenericApplicationContext:支持多种配置方式,XML、注解、手动注册的上下文。
-
Bean定义导入与组合
- ImportBeanDefinitionRegistrar:运行时动态注册 Bean,实现灵活配置,扩展配置类功能。
- ImportSelector:运行时动态导入配置类,实现条件选择和灵活配置。
- DeferredImportSelector:运行时动态导入配置,支持条件选择和按组别延迟加载。
-
Bean生命周期
- Bean的定义注册过程:加载与解析配置文件,注册解析Bean定义,类名、作用域、属性等。
- Bean的初始化过程:实例化、属性注入、Aware回调、后置处理器、初始化方法调用。
- Bean的依赖解析过程:声明依赖,查找依赖,注入依赖,处理循环依赖,延迟依赖解析。
- Bean的销毁过程:销毁方法调用,接口回调,后处理清理,通知触发,GC回收资源。
-
属性解析和环境配置
- PropertySource:管理各种配置源的抽象类,支持灵活地加载和访问应用配置。
- PropertySources:用于统一管理和访问多个 PropertySource 实例,简化配置数据的处理。
- PropertyResolver:通用属性解析,获取配置值,处理属性缺失,简便灵活。
- ConfigurablePropertyResolver:属性解析配置,占位符设置,适应不同配置需求。
- Environment:应用环境表示,提供属性访问,支持配置文件,实现动态配置。
- ConfigurableEnvironment:动态配置应用环境,激活、默认配置,提升应用灵活性。
-
Bean初始化与扩展点
- InitializingBean:提供Bean初始化时执行自定义逻辑的接口。
- DisposableBean:定义Bean销毁前执行清理操作的接口。
- BeanDefinitionRegistryPostProcessor:在容器启动时,对BeanDefinition动态修改或添加。
- BeanFactoryPostProcessor:在Bean实例化前,对BeanFactory进行全局修改或配置。
- BeanPostProcessor:在Bean初始化前后,进行自定义处理,可影响所有Bean。
- InstantiationAwareBeanPostProcessor:提供更深层次的实例化和属性注入控制。
- DestructionAwareBeanPostProcessor: 允许在Bean销毁前进行额外的清理操作。
- MergedBeanDefinitionPostProcessor:在合并Bean定义时对BeanDefinition进行处理。
- SmartInstantiationAwareBeanPostProcessor:提供更智能的实例化控制。
- SmartInitializingSingleton:在所有单例Bean初始化完成后,执行自定义逻辑。
-
Aware接口系列
- BeanNameAware:让Bean获取自身在容器中的名字。
- BeanClassLoaderAware:允许Bean获取其类加载器。
- BeanFactoryAware:提供Bean获取所属的BeanFactory。
- EnvironmentAware:允许Bean获取应用程序环境配置。
- EmbeddedValueResolverAware:允许Bean解析嵌入式值占位符。
- ResourceLoaderAware:允许Bean获取资源加载器。
- ApplicationEventPublisherAware:允许Bean发布应用程序事件。
- MessageSourceAware:允许Bean获取消息源。
- ApplicationStartupAware:允许Bean获取应用程序启动信息。
- ApplicationContextAware:允许Bean获取应用程序上下文。
- ImportAware:允许被导入的配置类获取导入它的类的信息。
-
核心注解
- @Configuration:声明类为配置类,定义Bean和Bean之间的依赖关系。
- @ComponentScan:启用组件扫描,自动发现并注册标记为组件的类。
- @Bean:在配置类中声明方法,返回Bean实例。
- @Import:引入其他配置类,将其Bean定义合并到当前容器。
- @PropertySource:指定属性文件,加载外部配置到环境中。
- @DependsOn:指定Bean的依赖顺序,确保特定Bean在其他Bean之前初始化。
- @Conditional:根据条件决定是否创建Bean。
- @Lazy:指定Bean的延迟初始化,只有在首次使用时才创建。
- @Value:注入简单值或表达式到Bean的字段或方法参数。
- @Autowired:自动装配Bean依赖。
- @Primary:指定在多个候选Bean中优先选择的首选Bean。
- @Description:为Bean提供描述性信息。
- @Role:为Bean提供角色提示,用于区分相似类型的Bean。
- @Indexed: 标记Bean用于索引。
- @Order:指定Bean的加载顺序。
-
JSR规范
- @Inject:JSR-330标准的依赖注入注解。
- @Named:JSR-330标准的命名注解。
- @Resource:Java EE标准的资源注入注解。
- @Qualifier:用于限定注入的Bean。
- @Scope:指定Bean的作用域。
- @Singleton:指定Bean为单例。
- @PostConstruct:指定初始化方法。
- @PreDestroy:指定销毁方法。
- Provider:Java标准库提供的通用Bean工厂接口。
-
Spring AOP
- JDK动态代理:接口实现,动态生成代理类,处理方法调用,统一横切关注点。
- Cglib动态代理:基于字节码生成的库,无需接口,可拦截类方法并进行增强。
- AopProxy:创建和管理AOP代理对象。
- ClassFilter:确定类是否匹配拦截条件。
- MethodMatcher:确定方法是否匹配拦截条件。
- Pointcut:定义切入点,匹配被拦截的方法。
- Advice:AOP核心接口,定义切面通知行为。
- MethodInterceptor:拦截方法执行,允许在前后添加额外逻辑。
- Advisor:用于将通知和切点结合,实现切面编程的横切关注点。
- AdvisorAdapter:适配不同类型通知到拦截器链。
- TargetSource:管理AOP代理对象的获取与释放。
-
Spring AOT
-
Spring Log
-
Data Buffer 和编解码器
-
-
Spring MVC
-
Spring 事务
-
Spring OpenFeign
💬与我联系
✉️ Email | 💬 Issue | 🌐 CSDN Me about everything!
⛵欢迎贡献!
如果你发现任何错误🔍或者有改进建议🛠️,欢迎提交 issue 或者 pull request。你的反馈📢对于我非常宝贵💎!
🔄持续更新中
为了给大家提供最新🌱、最有价值的内容💼,我会坚持每天更新这个仓库⏳。每一天,你都可以期待看到一些新的内容或者对已有内容的改进✨。如果你有任何建议或反馈📣,欢迎随时联系我📞。我非常珍视每一个反馈💌,因为这是我持续改进的动力🚀。
💻我的 GitHub 统计
🍱请我吃盒饭?
作者晚上还要写博客✍️,平时还需要工作💼,如果帮到了你可以请作者吃个盒饭🥡
👥加入我们
📢 想要一起加入我们的精彩微信群吗?跟着以下简单步骤:
1️⃣ 扫描我的二维码:使用微信的扫一扫功能,扫描下方的二维码,将我添加为你的好友。
2️⃣ 等待好友请求被接受:一旦你的好友请求被接受,你将收到一份群组邀请。
3️⃣ 点击邀请链接:打开邀请链接,立即加入我们的精彩群组!
4️⃣ 尽情参与和分享:在群组中,你将有机会与其他成员分享观点、经验和信息。我们热切期待你的参与!