MCPcopy Index your code
hub / github.com/xuchengsheng/spring-reading

github.com/xuchengsheng/spring-reading @main

repository ↗ · DeepWiki ↗ · Ask this repo → · + Follow
967 symbols 1,653 edges 448 files 263 documented · 27% updated 1y ago★ 9,92630 open issues
README
<img alt="logo" src="https://github.com/xuchengsheng/spring-reading/raw/main/image/banner.png" style="height: 80px">






<h2>深入Spring,从源码开始!</h2>
<h4>探索Java最受欢迎的框架,理解它的内部机制,带大家从入门到精通。</h4>






<a href="https://github.com/xuchengsheng/spring-reading/stargazers"><img src="https://img.shields.io/github/stars/xuchengsheng/spring-reading?logo=github&logoColor=%23EF2D5E&label=Stars&labelColor=%23000000&color=%23EF2D5E&cacheSeconds=3600" alt="Stars Badge"/></a>
<a href="https://github.com/xuchengsheng"><img src="https://img.shields.io/github/followers/xuchengsheng?label=Followers&logo=github&logoColor=%23FC521F&labelColor=%231A2477&color=%23FC521F&cacheSeconds=3600" alt="Follow Badge"></a>
<a href="https://github.com/xuchengsheng/spring-reading/fork"><img src="https://img.shields.io/github/forks/xuchengsheng/spring-reading?label=Forks&logo=github&logoColor=%23F2BB13&labelColor=%23BE2323&color=%23F2BB13" alt="Fork Badge"></a>
<a href="https://github.com/xuchengsheng/spring-reading/watchers"><img src="https://img.shields.io/github/watchers/xuchengsheng/spring-reading?label=Watchers&logo=github&logoColor=%23FF4655&labelColor=%234169E1&color=%23FF4655&cacheSeconds=3600" alt="Watchers Badge"></a>






<img src="https://visitor-badge.lithub.cc/badge?page_id=github.com/xuchengsheng&left_text=Visitors" alt="Visitor Badge"/>
<img src="https://img.shields.io/badge/WeChat-spring_reading-%2307C160?logo=wechat" alt="Wechat Badge"/>
<a href="https://blog.csdn.net/duzhuang2399"><img src="https://img.shields.io/badge/dynamic/xml?url=https%3A%2F%2Fblog.csdn.net%2Fduzhuang2399&query=%2F%2F*%5B%40id%3D%22userSkin%22%5D%2Fdiv%5B1%5D%2Fdiv%5B2%5D%2Fdiv%5B1%5D%2Fdiv%2Fdiv%5B2%5D%2Fdiv%5B1%5D%2Fdiv%5B1%5D%2Fdiv%5B2%5D%2Fspan&logo=C&logoColor=red&label=CSDN&color=red&cacheSeconds=3600" alt="CSDN Badge"></a>
    <a href="https://hellogithub.com/repository/f43b683fa175499ca3af4e9b1684e88b" target="_blank"><img src="https://api.hellogithub.com/v1/widgets/recommend.svg?rid=f43b683fa175499ca3af4e9b1684e88b&claim_uid=AVv4KeNnZs2Ig3a&theme=small" alt="Featured|HelloGitHub"/></a>






⚡ <a href="#技术">技术</a>
|
👋 <a href="#简介">简介</a>
|
🍵 <a href="#为何做Spring源码分析">Why</a>
|
🙏 <a href="#顺手点个星">点个星</a>
|
🌱 <a href="#spring-源码阅读系列">Spring源码</a>
|
💬 <a href="#与我联系">联系我</a>
|
⛵ <a href="#欢迎贡献">贡献</a>
|
🔄 <a href="#持续更新中">更新</a>
|
💻 <a href="#我的-github-统计">统计</a>

⚡技术

<img src="https://img.shields.io/badge/Java-1.8%2B-%23437291?logo=openjdk&logoColor=%23437291"/>
<img src="https://img.shields.io/badge/Spring-5.3.10-%23437291?logo=Spring&logoColor=%236DB33F&color=%236DB33F"/>
<img src="https://img.shields.io/badge/SpringBoot-2.5.5-%23437291?logo=SpringBoot&logoColor=%236DB33F&color=%236DB33F"/>
<img src="https://img.shields.io/badge/Maven-3.6.3-%23437291?logo=Apache%20Maven&logoColor=%23C71A36&color=%23C71A36"/>
<img src="https://img.shields.io/badge/JSR-330-%2366CCFF?logo=OpenJDK&logoColor=%2366CCFF&color=%2366CCFF"/>
<img src="https://img.shields.io/badge/JSR-250-%23FF9900?logo=OpenJDK&logoColor=%23FF9900&color=%23FF9900"/>

👋简介

大家好呀,我是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定义与注册

  • Bean定义读取与扫描

  • Bean工厂

  • 容器上下文

  • Bean定义导入与组合

    • ImportBeanDefinitionRegistrar:运行时动态注册 Bean,实现灵活配置,扩展配置类功能。
    • ImportSelector:运行时动态导入配置类,实现条件选择和灵活配置。
    • DeferredImportSelector:运行时动态导入配置,支持条件选择和按组别延迟加载。
  • Bean生命周期

  • 属性解析和环境配置

    • PropertySource:管理各种配置源的抽象类,支持灵活地加载和访问应用配置。
    • PropertySources:用于统一管理和访问多个 Prop

Extension points exported contracts — how you extend this code

MessageService (Interface)
@author xcs @date 2023年10月20日 14时56分 [13 implementers]
spring-jsr/spring-jsr330-qualifier/src/main/java/com/xcs/spring/service/MessageService.java
ScoresService (Interface)
(no doc) [6 implementers]
spring-transaction/spring-transaction-enableTransactionManagement/src/main/java/com/xcs/spring/ScoresService.java
ScoresService (Interface)
(no doc) [6 implementers]
spring-transaction/spring-transaction-springTransactionAnnotationParser/src/main/java/com/xcs/spring/ScoresService.java
ScoresService (Interface)
(no doc) [6 implementers]
spring-transaction/spring-transaction-transactionInterceptor/src/main/java/com/xcs/spring/ScoresService.java
ScoresService (Interface)
(no doc) [6 implementers]
spring-transaction/spring-transaction-transactionAttributeSource/src/main/java/com/xcs/spring/ScoresService.java
UserValidator (Interface)
(no doc) [5 implementers]
spring-aware/spring-aware-beanFactoryAware/src/main/java/com/xcs/spring/validate/UserValidator.java
DataBase (Interface)
@author xcs @date 2023年09月16日 16时10分 [2 implementers]
spring-interface/spring-interface-instantiationAwareBeanPostProcessor/src/main/java/com/xcs/spring/service/DataBase.java
ConnectionService (Interface)
@author xcs @date 2023年09月18日 17时29分 [2 implementers]
spring-interface/spring-interface-destructionAwareBeanPostProcessor/src/main/java/com/xcs/spring/service/ConnectionService.java

Core symbols most depended-on inside this repo

getName
called by 40
spring-aop/spring-aop-pointcut/src/main/java/com/xcs/spring/MyService.java
add
called by 14
spring-spel/spring-spel-methodResolver/src/main/java/com/xcs/spring/MyBean.java
matches
called by 12
spring-aop/spring-aop-pointcut/src/main/java/com/xcs/spring/MyCustomPointcut.java
convert
called by 9
spring-dataops/spring-dataops-converter/src/main/java/com/xcs/spring/converter/StringToBooleanConverter.java
getMessage
called by 7
spring-jsr/spring-jsr330-qualifier/src/main/java/com/xcs/spring/service/MessageService.java
showMatchesLog
called by 5
spring-aop/spring-aop-pointcut/src/main/java/com/xcs/spring/PointcutDemo.java
parse
called by 3
spring-dataops/spring-dataops-parser/src/main/java/com/xcs/spring/parser/CurrencyParser.java
getResource
called by 3
spring-aware/spring-aware-resourceLoaderAware/src/main/java/com/xcs/spring/config/MyResourceLoaderAware.java

Shape

Method 532
Class 414
Interface 21

Languages

Java100%

Modules by API surface

spring-factory/spring-factory-autowireCapableBeanFactory/src/main/java/com/xcs/spring/AutowireCapableBeanFactoryDemo.java11 symbols
spring-interface/spring-interface-instantiationAwareBeanPostProcessor/src/main/java/com/xcs/spring/service/DataBaseImpl.java8 symbols
spring-beans/spring-bean-beanDefinition/src/main/java/com/xcs/spring/bean/MyBean.java8 symbols
spring-aop/spring-aop-pointcut/src/main/java/com/xcs/spring/PointcutDemo.java8 symbols
spring-interface/spring-interface-instantiationAwareBeanPostProcessor/src/main/java/com/xcs/spring/service/DataBase.java7 symbols
spring-aop/spring-aop-targetSourceCreator/src/main/java/com/xcs/spring/ConnectionPoolTargetSource.java7 symbols
spring-aop/spring-aop-targetSource/src/main/java/com/xcs/spring/ConnectionPoolTargetSource.java7 symbols
spring-transaction/spring-transaction-jdbcTemplate/src/main/java/com/xcs/spring/Scores.java6 symbols
spring-spel/spring-spel-evaluationContext/src/main/java/com/xcs/spring/EvaluationContextDemo.java6 symbols
spring-factory/spring-factory-autowireCapableBeanFactory/src/main/java/com/xcs/spring/service/MyService.java6 symbols
spring-dataops/spring-dataops-propertyEditor/src/main/java/com/xcs/spring/bean/MyBean.java6 symbols
spring-dataops/spring-dataops-genericConverter/src/main/java/com/xcs/spring/bean/MyBean.java6 symbols

Dependencies from manifests, versioned

cn.hutool:hutool-json5.8.27 · 1×
jakarta.annotation:jakarta.annotation-api1.3.5 · 1×
javax.inject:javax.inject1 · 1×
mysql:mysql-connector-java
org.codehaus.groovy:groovy-ant3.0.19 · 1×
org.codehaus.groovy:groovy-astbuilder3.0.19 · 1×
org.codehaus.groovy:groovy-cli-picocli3.0.19 · 1×
org.codehaus.groovy:groovy-console3.0.19 · 1×
org.codehaus.groovy:groovy-datetime3.0.19 · 1×
org.codehaus.groovy:groovy-docgenerator3.0.19 · 1×
org.codehaus.groovy:groovy-groovydoc3.0.19 · 1×

Datastores touched

(mysql)Database · 1 repos
spring-readingDatabase · 1 repos

For agents

$ claude mcp add spring-reading \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact