Spring源代码分析-代码下载

一. 简介

spring的大名想必做过Java后台的同学都不会陌生,什么spring mvc, spring boot,spring全家桶等等,所以想系统学习下spring的源代码。
而学习源代码的话,首先得去下载spring的源代码,目前spring的源代码都开放在github上面,在下面地址,大家去用git clone即可。

https://github.com/spring-projects/

二. spring结构简介

spring有3个基础框架,其他的服务是基于这3个基础框架spring-core, spring-context, spring-beans,这3个统一放在spring-framework里面。

调试spring源码控制台乱码 spring 源代码_调试spring源码控制台乱码

三. 编译

每个项目里面有介绍,然后用IntelliJ IDEA打开代码即可,如下:

调试spring源码控制台乱码 spring 源代码_后端_02

四. 研究入口

由于自己项目里面使用springboot比较多,所以决定从springboot入手开始研究,springboot的源代码在上面spring project的源代码页面有链接。

看代码之前,我一般先问自己几个问题

  1. springboot怎么启动的?
  2. springboot怎么启动tomcat的?因为我们只要写几个映射,就可以完成几个restful接口。
  3. 接口访问时怎么调用到springboot里面的,也就是tomcat怎么和springboot关联起来?

带着这些问题,然后再去看源代码,希望会有点收获。

五. 源代码编译

自己使用了1.5.x分支代码,执行如下指令:
mvn clean install -DskipTests -Pfast

六. 代码导入

使用IntelliJ IDEA import Spring Boot目录,导入完毕的目录结构:

调试spring源码控制台乱码 spring 源代码_java_03

七. 启动测试

我们以spring-boot-samples里面的spring-boot-simple-tomcat为例,启动springboot测试
找到SampleTomcatApplication.java->右击->Run

调试spring源码控制台乱码 spring 源代码_程序人生_04

然后浏览器输入
http://localhost:8080/

效果如下:

调试spring源码控制台乱码 spring 源代码_调试spring源码控制台乱码_05

八. 修改springboot源代码并运行

我们跑springboot的源代码的目的就是修改它,调试它。所以我们可以先简单的修改下源代码,看看能不能跑起来。
找到SpringApplication.java的run(Object source, String… args)方法,加入一行日志打印,如下:

调试spring源码控制台乱码 spring 源代码_java_06

然后我们再运行simple-tomcat,观看日志

调试spring源码控制台乱码 spring 源代码_调试spring源码控制台乱码_07

果然看到了日志已经打印,也就是后面我们可以通过日志等方式来调试springboot的源代码了。

参考

  1. 源代码编译参考链接
  2. Springboot源代码学习