Spring源码调试环境搭建(IDEA)

文章目录

引言

无论是面试,还是工作,Spring源码都是一个非常值得学习的内容。在开发和调试 Spring应用程序时,有时候需要深入理解框架的内部实现以及解决一些复杂的问题。为了更好地理解和调试 Spring源码,我们可以搭建一个本地的源码调试环境。本文将详细介绍如何通过下载源码、配置开发环境和启动调试来搭建这样的环境。

开发环境

JDK:

确保安装了 JDK,建议使用 JDK 8 或更高版本。

IDE:

推荐使用 IntelliJ IDEA 或 Eclipse 等流行的 Java IDE。这里我们以 IntelliJ IDEA 为例。

构建工具:

Maven 或 Gradle。Spring Boot 新版本开始默认使用 Gradle,所以我们这里以 Gradle 为例。

搭建步骤

步骤一:下载 Spring Boot 源码

首先,我们需要获取 Spring Boot 的源代码。你可以通过以下方式获取:

从 GitHub 获取源码(推荐):

Spring Boot 的源码托管在 GitHub 上,你可以访问GitHub 页面spring官方代码。在页面右侧可以看到一个绿色的按钮 "Code",点击后可以选择下载 ZIP 文件或者使用 Git 克隆仓库到本地。

左上角选择版本,进行下载,解压(我选择的是5.2.x)

步骤二:导入项目到 IntelliJ IDEA

IntelliJ IDEA,选择 File -> New -> Project from Existing Sources,然后选择 Spring项目的根目录。
选择gradle

等待加载

步骤三:处理build报错

报错一

项目导入后会自动编译,首先会报错:

bash 复制代码
POM relocation to an other version number is not fully supported in Gradle : xml-apis:xml-apis:2.0.2 relocated to xml-apis:xml-apis:1.0.b2.

解决方案:

项目根目录下的build.gradle文件中添加如下代码,指定xml-apis的版本为1.0.b2

bash 复制代码
configurations.all {
    resolutionStrategy {
        force 'xml-apis:xml-apis:1.0.b2'
    }
}

报错二

bash 复制代码
Build scan background action failed.
org.gradle.process.internal.ExecException: A problem occurred starting process 'command 'git''
	at org.gradle.process.internal.DefaultExecHandle.execExceptionFor(DefaultExecHandle.java:237)
	at org.gradle.process.internal.DefaultExecHandle.setEndStateInfo(DefaultExecHandle.java:214)
	at org.gradle.process.internal.DefaultExecHandle.failed(DefaultExecHandle.java:364)
	at org.gradle.process.internal.ExecHandleRunner.run(ExecHandleRunner.java:87)
	at org.gradle.internal.operations.CurrentBuildOperationPreservingRunnable.run(CurrentBuildOperationPreservingRunnable.java:38)
	at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:64)
	at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:48)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:56)
	at java.lang.Thread.run(Thread.java:748)
Caused by: net.rubygrapefruit.platform.NativeException: Could not start 'git'
	at net.rubygrapefruit.platform.internal.DefaultProcessLauncher.start(DefaultProcessLauncher.java:27)
	at net.rubygrapefruit.platform.internal.WindowsProcessLauncher.start(WindowsProcessLauncher.java:22)
	at net.rubygrapefruit.platform.internal.WrapperProcessLauncher.start(WrapperProcessLauncher.java:36)
	at org.gradle.process.internal.ExecHandleRunner.startProcess(ExecHandleRunner.java:98)
	at org.gradle.process.internal.ExecHandleRunner.run(ExecHandleRunner.java:71)
	... 7 more
Caused by: java.io.IOException: Cannot run program "git" (in directory "D:\wenjian\workspace\spring-framework-5.2.x\spring-framework-5.2.x"): CreateProcess error=2, ϵͳ�Ҳ���ָ�����ļ���
	at java.lang.ProcessBuilder.start(ProcessBuilder.java:1048)
	at net.rubygrapefruit.platform.internal.DefaultProcessLauncher.start(DefaultProcessLauncher.java:25)
	... 11 more
Caused by: java.io.IOException: CreateProcess error=2, ϵͳ�Ҳ���ָ�����ļ���
	at java.lang.ProcessImpl.create(Native Method)
	at java.lang.ProcessImpl.<init>(ProcessImpl.java:386)
	at java.lang.ProcessImpl.start(ProcessImpl.java:137)
	at java.lang.ProcessBuilder.start(ProcessBuilder.java:1029)
	... 12 more

BUILD SUCCESSFUL in 203ms

解决方案:

项目根目录下的build.gradle文件中注释掉

bash 复制代码
id 'io.spring.ge.conventions' version '0.0.7'

再次编译,成功!

测试步骤

新建module


修改build.gradle

新建module中的build.gradle 中的dependencies添加

bash 复制代码
compile(project(":spring-beans"))
compile(project(":spring-context"))

新建测试类


启动类:

java 复制代码
public class LufeiApplication {
	public static void main(String[] args) {
		AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(TestConf.class);
		System.out.println(context.getBean(User.class));
	}
}

配置类:

java 复制代码
package com.lufei;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan("com.lufei")
public class TestConf {
}

实体类

java 复制代码
package com.lufei;

import org.springframework.stereotype.Component;

@Component
public class User {

	private Integer id;

	private String name;

	public Integer getId() {
		return id;
	}

	public void setId(Integer id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
}

启动测试

如下,可以打印出对象地址了。后续可以自己debug spring的源码研究研究bean的实例化,初始化过程等。

相关推荐
黑胡子大叔的小屋18 分钟前
基于springboot的海洋知识服务平台的设计与实现
java·spring boot·毕业设计
ThisIsClark20 分钟前
【后端面试总结】深入解析进程和线程的区别
java·jvm·面试
雷神乐乐1 小时前
Spring学习(一)——Sping-XML
java·学习·spring
小林coding2 小时前
阿里云 Java 后端一面,什么难度?
java·后端·mysql·spring·阿里云
V+zmm101342 小时前
基于小程序宿舍报修系统的设计与实现ssm+论文源码调试讲解
java·小程序·毕业设计·mvc·ssm
文大。2 小时前
2024年广西职工职业技能大赛-Spring
java·spring·网络安全
一只小小翠2 小时前
EasyExcel 模板+公式填充
java·easyexcel
m0_748256343 小时前
QWebChannel实现与JS的交互
java·javascript·交互
Jelena技术达人3 小时前
Java爬虫获取1688关键字 item_search接口返回值详细解析
java·开发语言·爬虫
u0107735143 小时前
【字符串】-Lc5-最长回文子串(中心扩展法)
java·算法