源码学习第一步,Spring源码编译
之所以写这么一篇文章是因为群里的小伙伴在编译源码时碰到了问题,再加上笔者自身正准备做一个源码的注释版本,恰好也需要重新编译一份代码,至于为什么要将源码编译到本地就不用多说了吧?
比如,你可以任意的添加注释,一边读源码一边记笔记,甚至你可以修改源码,更好的调试程序等等。但是如果你坚持通过导入依赖或者引入jar包的方式来学习源码,我觉得也可以,没有最好的,只有最适合自己的!
本文的主要目的是帮助那些在源码学习之初就被源码编译劝退的同学重拾信心!
话不多说,我们开始正题
参考官方文档:
https://github.com/spring-projects/spring-framework/wiki/Build-from-Source
https://github.com/spring-projects/spring-framework/blob/master/import-into-idea.md
前期准备
- 确保本机已经安装好了
git
jdk
对应版本为1.8
Gradle
,目前不需要安装,在编译的时候根据源码提示按照对应版本的Gradle
即可IDEA
,我使用的版本如下:
1、获取Spring源码
这里我推荐使用clone的方式将源码拉取到本地,最大的好处在于可以利用IDEA直接比较版本间的差异,例如
在上图中我本地编译的5.0
版本的代码,所以我对比的是5.0
跟5.1
版本populateBean
方法实现的差异。
接下来我们开始拉取Spring源码,大家可以按照以下几步进行
- 在任意磁盘路径下新建一个文件夹,名称随便取,建议为
SpringFramWork
- 进入
SpringFramWork
文件夹中,打开git
命令行,输入以下命令
git clone https://github.com/spring-projects/spring-framework.git
接着等待仓库克隆完毕,这个过程可能会耗费比较长的时间,如果实在不行的话,大家可以直接将源码的压缩包down下来。
如果你是跟我一样直接拉取的代码,记得切换到5.2.x
版本,在命令行中执行命令:
git checkout origin/5.2.x
2、添加阿里云镜像
在编译过程中,Spring会去自动下载一些依赖的包,默认使用的是官方的镜像,下载比较慢,所以我们提前添加好国内镜像,将下面这行代码粘贴到build.gradle
文件中的repositories
节点下即可 ,
//添加阿里云镜像
maven { url "http://maven.aliyun.com/nexus/content/groups/public" }
如下图所示
3、预先编译spring-oxm模块
打开命令行窗口,并切换到源码所在文件夹,执行以下命令
gradlew :spring-oxm:compileTestJava
出现BUILD SUCCESS
字样时说明构建成功,如下图所示
4、根据编译后的源码下载并安装对应的版本的Gradle
在完成对spring-oxm
模块的编译后,会在当前目录生成一个.gradle
文件夹,打开后可以查看对应的Gradle
版本。
双击打开.gradle
文件夹就能看到对应所需要的gradle
的版本号
大家直接在这个网站上下载对应所需要的版本即可:https://gradle.org/releases/,选择 binary-only
安装好后记得配置Gradle
的环境变量
- 新增
GRADLE_HOME
环境变量,指向Gradle解压目录 - 配置Path环境变量:新增
%GRADLE_HOME%\bin
之后测试是否安装成,在命令行中输入以下命令:gradle -v
,查看是否正确输出了对应版本。
5、为安装好的Gradle配置国内镜像
进入Gradle
安装目录,在init.d
目录下新建一个init.gradle
文件,并添加以下内容:
allprojects{
repositories {
def REPOSITORY_URL = 'http://maven.aliyun.com/nexus/content/groups/public/'
all { ArtifactRepository repo ->
def url = repo.url.toString()
if ((repo instanceof MavenArtifactRepository) && (url.startsWith('https://repo1.maven.org/maven2') || url.startsWith('https://jcenter.bintray.com'))) {
project.logger.lifecycle 'Repository ${repo.url} replaced by $REPOSITORY_URL .'
remove repo
}
}
maven {
url REPOSITORY_URL
}
}
}
如下图所示:
6、将代码导入到IDEA中
6.1、打开IDEA并选择导入项目
6.2、选择导入一个Gradle项目
6.3、配置导入的项目
点击Finish
后等待IDEA构建完项目,如果你之前已经按照我的方法配置了Gradle
的国内镜像,这个过程不会太久,我们本机只用了10多分钟就构建完成了
构建完成后整个项目结构如下:
如果你跟我一样是直接检出的代码,记得将分支切换到5.2.x
7、构建整个项目
选择Build > Build Project
可能出现的问题
AnnotationCacheAspect找不到符号
在这个过程中你可能会碰到如下错误:
这是因为AnnotationCacheAspect.aj
不是java文件需要另外的aspectj
进行处理,可以按照以下步骤解决这个问题
-
下载
aspectj
,对应链接:https://www.eclipse.org/downloads/download.php?file=/tools/aspectj/aspectj-1.9.5.jar -
安装
aspectj
打开命令行,cd到AspectJ的jar包所在的文件夹,运行java -jar aspectj-1.9.4.jar
命令,打开AspectJ的安装界面,直接点击Next,如下图:
接着选择jdk
的安装路径,继续Next。
接着选择AspectJ
的安装路径,然后Install安装。
- IDEA中配置
aspectj
确保以下两个插件已经被激活
-
Spring AOP/@AspectJ
-
AspectJ Support
将编译器改为 Ajc,接着设置Ajc的安装目录,选择到aspectjtools.jar,同时,一定要将Delegate to Javac选项打钩,这个代理设置的作用只对指定的项目进行Ajc编译,其他的项目还是用默认的javac编译器编译。如果不勾选这个代理选项,则全部项目都使用Ajc编译器编译,可能会导致编译错误。
- 指定需要使用Ajc编译的项目
分别为spring-aop
及spring-aspects
添加Facets
属性。
点击File --> Project Structure --> Facets,选择spring-aop.main
,点击OK
点击File --> Project Structure --> Facets,选择spring-aspects.main
,点击OK
完成添加,如下图所示:
完成上述步骤后,再次选择Build > Build Project
,成功完成编译
8、添加测试模块
8.1、右键工程名 ---> new ---> module
8.2、选择Gradle及Java
8.3、输入模块名称
点击next ---> Finish 完成测试模块的创建
最后,添加一些必要的依赖,修改创建好的模块中的build.gradle
文件,添加如下三个依赖
compile(project(":spring-aop"))
compile(project(":spring-context"))
optional("org.aspectj:aspectjweaver")
如下图所示:
至此,我们就完成了整个Spring的编译,并且在创建了一个日后学习使用的模块!
如果本文对你有帮助的话,记得点个赞吧!也欢迎关注我的公众号,微信搜索:程序员DMZ,或者扫描下方二维码,跟着我一起认认真真学Java,踏踏实实做一个coder。