Spring源码环境搭建

时间:2022-09-18 15:27:08

前言

Spring源码学习,需要搭建一个Spring源码的运行环境,需要做以下几件事:

1,安装JDK(略)
2,从GitHub获取Spring源码
3,安装Gradle(略)
4,安装IDE-eclipse,并导入源码(安装Gradle插件)

由于我们打算使用spring3.2.x源码进行环境搭建,而目前这一版本的搭建过程有很多坑
在网上也搜罗了一些博文,几乎都不能实现,所以这里把我的搭建过程记录下来,和大家分享

获取Spring源码

通过GitHub获取Spring源码,我们使用Spring 3.2.x为例:

https://github.com/spring-projects/spring-framework/tree/3.2.x

下载Spring各模块依赖的jar包

本来想将源码导入到IDEA,查看了源码目录下的import-into-idea.md,介绍如何将源码导入idea

Spring源码环境搭建

按照说明,执行了第一步发现并没有成功,所以直接执行 gradlew命令

Spring源码环境搭建

导入Idea->选择gradle,等待下载文件,这种方式需要解决很多代码错误,我们先TODO,暂时选用eclipse

Spring源码目录结构如下:

Spring源码环境搭建

由于GitHub上的Spring源码由Gradle构建,需下载Spring各模块依赖的jar包
所以不能立即导入IDE,并且需要gradle命令生成对应的IDE文件
// TODO 需要一篇 gradle生成eclipse和idea项目的博文

以eclipse为例,导入eclipse的项目需要.project和.classpath文件,需要执行gradle命令:

gradle cleanidea eclipse

gradle eclipse -x :eclipse

打开命令窗口,将当前目录切换至Spring源码所在目录,并执行gradle cleanidea eclipse

这里需要注意:
执行gradle cleanidea eclipse后生成的代码的jar依赖关系路径为当前源码所在目录
这将影响我们后面导入包的依赖路径

Spring源码环境搭建

Spring源码环境搭建

等待项目转换完成后导入IDE

注意:
Spring源码根路径下的build.gradle文件中有类似这样一句:

compileJava {
sourceCompatibility = 1.6
targetCompatibility = 1.6
}

compileTestJava {
sourceCompatibility = 1.8
targetCompatibility = 1.8
options.compilerArgs += "-parameters"
}

是指定源码编译使用jdk1.6,测试代码编译使用jdk1.8,也就是说当前编译我们需要安装jdk1.8

将Spring源码导入IDE

通过eclipse->import导入Spring-framework源码目录

Spring源码环境搭建

导入完成目录,会有很多报错:

Spring源码环境搭建

项目右键BulidPath:

Spring源码环境搭建

发现缺少两个jar包:

spring-cglib-repack-3.1.0.jar和spring-asm-repack-5.0.4.jar

Spring源码环境搭建


解决Spring源码jar包缺失问题

这里我们要问了:这么多jar包都不缺,为什么缺这俩,而且细看发现很多模块都缺这俩

我们对项目做了一个搜索(当然这里是已经知道原因了,只是把说明抓出来给大家看看)

Spring源码环境搭建

打开gclib的jar缺失文件

Spring源码环境搭建

所以,我们知道:

Spring为了避免第三方class的冲突,repack掉了cglib和asm的jar

问题清晰了,我们就来解决问题:

正常来讲,需要下载高版本Spring源码,找到这两部分的代码自己打JAR包

这里我们直接给出jar:

Spring源码环境搭建

将Jar导入工程,放在spring-core工程的build/lib目录下面,并clean工程重新Build

eclipse-Tomcat配置问题

解决了以上问题Build项目依然会报错

Spring源码环境搭建

这是因为eclipse没有配置tomcat,导致web工程报错

Spring源码环境搭建


spring-oxm模块jar缺失问题

clean并重新Build后发现还有少jar的情况:

Spring源码环境搭建

显示在spring-oxm模块仍缺失3个jar包,在spring-oxm我们发现了oxm.gradle文件

Spring源码环境搭建

oxm.gradle类似Maven的pom文件,其中记录了项目依赖的jar信息

Spring源码环境搭建

我们可以看到包名,并通过命令行执行gradle命令下载jar

进入spring-oms目录,执行 gradle+空格+task名

下载完成后,进入gradle仓库找到jar,并导入工程

gradle下载jar的默认路径:
Mac系统默认下载到:/Users/(用户名)/.gradle/caches/modules-2/files-2.1
Windows系统默认下载到:C:\Users\(用户名)\.gradle\caches\modules-2\files-2.1

Spring源码环境搭建

更简单的方法是,安装eclipse-gradle插件:

利用 Install new softwate -> Install,
输入插件网址 http://dist.springsource.com/release/TOOLS/gradle,
安装完需要重启 Eclipse

Spring源码环境搭建

插件生效后使用插件将项目转换为gradle项目:

Spring源码环境搭建

转换完成后,使用插件下载jar

Spring源码环境搭建

这里可能会报一个错误:

error in opening zip file
Could not install Gradle distribution from ‘https://services.gradle.org/distributions/gradle-2.2.1-bin.zip‘.

选择需要的版本下载这个文件,并放入Gradle文件:

https://services.gradle.org/distributions/

导入路径:

Spring源码环境搭建

重新Build工程,不在报错:

Spring源码环境搭建

[sts] -----------------------------------------------------
[sts] Starting Gradle build for the following tasks:
[sts] :spring-oxm:cleanEclipse
[sts] :spring-oxm:eclipse
[sts] -----------------------------------------------------
:buildSrc:compileJava UP-TO-DATE
:buildSrc:compileGroovy UP-TO-DATE
:buildSrc:processResources UP-TO-DATE
:buildSrc:classes UP-TO-DATE
:buildSrc:jar UP-TO-DATE
:buildSrc:assemble UP-TO-DATE
:buildSrc:compileTestJava UP-TO-DATE
:buildSrc:compileTestGroovy UP-TO-DATE
:buildSrc:processTestResources UP-TO-DATE
:buildSrc:testClasses UP-TO-DATE
:buildSrc:test UP-TO-DATE
:buildSrc:check UP-TO-DATE
:buildSrc:build UP-TO-DATE
:spring-oxm:cleanEclipseClasspath
:spring-oxm:cleanEclipseJdt
:spring-oxm:cleanEclipseJdtUi
:spring-oxm:cleanEclipseProject
:spring-oxm:cleanEclipse
:spring-oxm:eclipseClasspath
:spring-oxm:eclipseJdtPrepare
:spring-oxm:eclipseJdt
:spring-oxm:eclipseProject
:spring-oxm:eclipseSettings
:spring-oxm:eclipseWstComponent
:spring-oxm:eclipse

BUILD SUCCESSFUL

Total time: 3.411 secs
[sts] -----------------------------------------------------
[sts] Build finished succesfully!
[sts] Time taken: 0 min, 3 sec
[sts] -----------------------------------------------------

之后spring-oxm继续报错:

Spring源码环境搭建

需要spring-oxm项目右键->Gradle(STS)->Enable Dependency Managemrnt

Spring源码环境搭建

之后可能继续出现:Flight cannot be resolved to a type错误

jre版本问题

导入了上边缺失的jar后,重新Build还会报错误:

Spring源码环境搭建

这是jre的问题,我们重新设置一下就好

Spring源码环境搭建

点击 Add Librart,选择JRE System Library重新添加jre:

Spring源码环境搭建


spring-test-mvc项目依赖问题

spring-test-mvc项目缺一个依赖:spring-webmvc-tiles3,添加依赖即可修复

spring-oxm模块test报错

Spring源码环境搭建

Spring源码环境搭建

这里的test报错其实是spring源码中的一个错误,需要我们手动修改一下:
这里也是本次源码导入最耗时的一个步骤了,看了报错的类,觉得可能是代码有问题
于是一步一步尝试修改了好久,最后,无意间找到了这个,对照修复即可:
http://code.taobao.org/p/cnspring/diff/2/trunk/spring-oxm/src/test/java/org/springframework/oxm

这里我们也可以直接注释掉报错的test代码

Could not find com.itextpdf:itextpdf:4.2.2

有可能会报出这个错误:

Spring源码环境搭建

错误原因: 因为3.2的版本比较久远,很多类库已经更新变化了
修改方法 :
1)gradle 仓库下找到ivy.xml
C:\Users\Brave\.gradle\caches\artifacts-24
\f103b4baf7311290346105b788d3b582 找到ivy.xml

2)将dependency org="com.itextpdf" name="itextpdf" rev="4.2.2"
修改为dependency dependency org="com.itextpdf" name="itextpdf" rev="5.2.0",
   <dependencies>
<dependency org="com.itextpdf" name="itextpdf" rev=“4.2.2" force="true"
conf="default->default;master->master;compile->compile;provided->provided;
runtime->runtime;system->system;sources->sources;javadoc->javadoc;
optional->optional"
/>

</dependencies>
修改为:
<dependencies>
<dependency org="com.itextpdf" name="itextpdf" rev="5.2.0" force="true"
conf="default->default;master->master;compile->compile;provided->provided;
runtime->runtime;system->system;sources->sources;javadoc->javadoc;
optional->optional"
/>

</dependencies>

项目导入完成

到这里,我们解决了导入过程的所有问题,Spring源码Build成功

最后我们回顾一下全部流程
1,下载源码并解压
2,将源码放到合适的路径,执行命令gradle cleanidea eclipse
3,下载依赖完成后,导入IDE
4,解决spring-core模块的jar缺失问题(添加到spring-core/build/libs)
5,使用gradle插件将spring-oxm转换成为gradle项目,并下载jar文件
6,spring-oxm项目右键->Gradle(STS)->Enable Dependency Managemrnt
7,处理依赖模块jre报错问题
8,解决spring-oxm模块test报错