Visual Studio Code 调试 SpringBoot
Build Anything with Spring Boot:Spring Boot is the starting point for building all Spring-based applications. Spring Boot is designed to get you up and running as quickly as possible, with minimal upfront configuration of Spring.

大概意思翻译一下:Spring Boot 是所有基于 Spring 开发的项目的起点。Spring Boot 的设计是为了让你尽可能快的跑起来 Spring 应用程序并且尽可能减少你的配置文件。这些都不再多说,Java 的Spring Boot我个人来说还是比较看好的。
Visual Studio Code (简称 VS Code / VSC) 是一款免费开源的现代化轻量级代码编辑器,支持几乎所有主流的开发语言的语法高亮、智能代码补全、自定义热键、括号匹配、代码片段、代码对比 Diff、GIT 等特性,支持插件扩展,并针对网页开发和云端应用开发做了优化。软件跨平台支持 Win、Mac 以及 Linux。他最强大的地方是微软的Language Server,这货可以通过插件的方法支持Java、C#、Python、Typescript、PHP....
说了这么多的废话,开始引出本文的重点:Spring Boot调试。
插件安装
在使用之前确保你已经安装了Java环境、安装了Vscode,然后安装下面的几个插件,至少需要这么几个插件:
Java 环境:
Java Extension Pack
Java Language Support
Debuger for Java
Spring boot 环境:
Spring Boot Extension Pack
Spring Boot Tools
Spring Initializr Java Support
Maven 环境:
Maven for Java
生成项目
开始生成项目:
Ctrl+Shift+P,输入Spring,选择Maven项目(我个人比较喜欢Maven),然后选择Java,输入项目名称假设为com.mx,然后输入项目名称假设为spider,然后我一般选择2.0.3,由于是测试项目,我只选择一个DevTools,然后选择目录生成项目,然后打开项目Open it。
需要注意一点,项目生成之后请先运行一下maven指令,下载必要的数据包。
然后下面就是激动人心的时刻了!
撸代码
测试代码是一个简单爬虫程序,爬取博客园博客数据。
首先在pom.xml文件中添加我们用到的包jsoup:
<dependency>
<!-- jsoup HTML parser library @ https://jsoup.org/ -->
<groupId>org.jsoup</groupId>
<artifactId>jsoup</artifactId>
<version>1.11.3</version>
</dependency>
然后我们首先找到src/main/java/com/mx/spider/DemoApplication.java文件,修改Spring Boot的启动行。
SpringApplication.run(DemoApplication.class, args);//删除启动项
System.out.println("Hello world!");
然后点击调试蜘蛛图标,直接点击调试(注意直接点击,先别配置,使用Vscode默认配置足以!),首次将会非常慢。结合我的原因,应该是maven下载数据包和初始化引擎所致。
代码调试
点击运行,妈耶!好神奇,环境好了!

来点复杂的调试
下面来点复杂的调试,首先我们创建一个模型Blog,一个控制器BlogSpiderController,然后开始下面的工作:
package com.mx.models;
public class Blog {
private String _url;
private String _title;
private String _detail;
public String getUrl() {
return _url;
}
public String getTitle() {
return _title;
}
public String getDetail() {
return _detail;
}
public void setUrl(String url) {
if (url.length() > 0 && (url.startsWith("http://") || url.startsWith("https://")))
_url = url;
}
public void setTitle(String title) {
if (title.length() > 0)
_title = title;
}
public void setDetail(String detial) {
if (detial.length() > 0)
_detail = detial;
}
}
package com.mx.controllers;
import java.util.ArrayList;
import java.util.List;
import com.mx.models.Blog;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
public class BlogSpiderController {
public void Run() throws Exception {
Document doc = null;
for (int i = 1; i <= 10; i++) {
doc = getUrlDocument("https://www.cnblogs.com/#p" + i);
for (Blog blog : getBlogListByDocument(doc)) {
bindBlogDetail(blog);
System.out.println(blog);
}
}
System.out.println("Task Finished!");
}
public Document getUrlDocument(String url) throws Exception {
Document doc = Jsoup.connect(url).get();
return doc;
}
public List<Blog> getBlogListByDocument(Document doc) throws Exception{
List<Blog> list = new ArrayList<Blog>();
Element pageList = doc.getElementById("post_list");
Elements blogs = pageList.getElementsByClass("post_item");
Blog b;
for (Element blog : blogs) {
b = new Blog();
b.setTitle(blog.getElementsByTag("h3").text());
b.setUrl(blog.getElementsByClass("titlelnk").get(0).attr("href"));
b.setSumary(blog.getElementsByClass("post_item_summary").text());
list.add(b);
}
return list;
}
public void bindBlogDetail( Blog blog) throws Exception{
//Do data bind
}
}
好了代码部分先写这么多,上文中绑定详细信息部分我不再写,因为几个步骤已经满足调试需求。
断点调试
- 按照vs习惯,下设断点。
同样的,在代码左侧双击下设断点,在断点监视器也可以随时修改断点。

- 点击调试
我的习惯是查看这几部分:
1). 变量属性
2). 堆栈调用情况
3). 变量变化情况
分别从下面几块儿查看数据。

- 查看调试信息


总结

本文主要使用Spring Boot Console程序演示Spring Boot的调试过程,但是Spring Boot如果是面向于Web端或许更加合适,但是Web代码编写相对复杂,所以选用了Console来演示调试过程。
【源代码】:YunFile
Visual Studio Code 调试 SpringBoot的更多相关文章
- Visual Studio Code 调试 PHP
Visual Studio Code 调试 PHP 2018/12/4 更新 Nginx + php-cgi.exe 下与 Visual Studio Code 配合调试 必需环境 Visual St ...
- Visual Studio Code调试node.js:无法在PATH上找到运行时的node
首先,环境变量Path中加入nodejs的路径: 验证nodejs是否已经加入环境变量: 接着,重新启动Visual Studio Code, 试一下,是不是好了~ 附录:Visual Studi ...
- Visual Studio Code调试electron主进程
Visual Studio Code调试electron主进程 作者: jekkay 分类: electron 发布时间: 2017-06-11 14:56 一·概述 此文原出自[水滴石]: htt ...
- windows下用visual studio code 调试go代码
http://www.golangtc.com/download下载安装包或压缩包 配置环境变量 配置GOROOT: 配置PATH:在PATH最后添加 配置GOPATH:GOPATH的作用请自行百度, ...
- 用 Visual Studio Code 调试 Node.js
环境: Visual Studio Code Node.js 1. 关闭运行中的程序 2.打开入口文件,我这里的入口文件为 app.js 3.点击左侧菜单栏的 debug 按钮 4.点击运行按钮 5 ...
- 使用Visual Studio Code调试基于ActionScript的LayaAir HTML5游戏
使用Visual Studio Code(VS Code)调试的优势 使用VS Code我们可以极大地提高LayaAir Html5游戏项目的调试效率,VS Code的优势有以下几点: 在发生Java ...
- visual studio code 调试nodejs 配置简单HTTP服务器
介绍 Visual Studio Code是一个轻量级的Web集成开发环境on Linux,Mac and Windows,特别是作为前端人员来了, 多了一个可供选择的生产力工具IDE,调试js代码简 ...
- Go学习笔记(二)搭建Visual Studio Code调试环境
上一篇 Go学习笔记(一)安装Go语言环境 安装Visual Studio Code 这是目前我觉得最好用的文本编辑器了, https://code.visualstudio.com/ 中间有几部确认 ...
- 使用visual studio code调试php代码
这回使用visual studio code折腾php代码的调试,又是一顿折腾,无论如何都进不了断点.好在就要放弃使用visual studio code工具的时候,折腾好了,汗~ 这里把步骤记录下来 ...
随机推荐
- Python+request 分模块存放接口,多接口共用参数URL、headers的抽离,添加日志打印等《三》
主要介绍内容如下: 1.分模块存放接口 2.多接口共用参数URL.headers的抽离为配置文件 3.添加日志打印 4.一个py文件运行所有所测的接口 如上介绍内容的作用: 1.分模块存放接口:方便多 ...
- appium+python 【Mac】UI自动化测试封装框架介绍 <五>---脚本编写(多设备)
目的: 通过添加设备号,则自动给添加的设备分配端口,启动对应的appium服务.注意:为了方便,将共用一个配置文件. 1.公共的配置文件名称:desired_caps.yaml platformVer ...
- ansible中roles的简单使用
一.初识roles 上节中我们已经了解了playbook,详见 https://www.cnblogs.com/wangtaobiu/p/10691689.html 当我们在配置playbook时会 ...
- Java8-Lambda-No.05
import java.util.HashMap; import java.util.function.BiConsumer; public class Lambda5 { //Pre-Defined ...
- [2019HDU多校第二场][HDU 6591][A. Another Chess Problem]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6591 题目大意:二维坐标系上,所有满足\(5|2x+y\)的点都被设为障碍物,无法通过.现给出一对点, ...
- Shell 脚本语法
条件测试:test 和 [ 命令 test 或 [ 可以测试一个条件是否成立,如果测试结果为真,则该命令的Exit Status为0,如果测试结果为假,则命令的Exit Status为1(注意与C ...
- 【luoguSP3267】--莫队,不同数字个数
题意翻译 给出一个长度为n 的数列,a1 a2 ,...an ,有q 个询问,每个询问给出数对(i,j),需要你给出ai ai+1 ,...,aj 这一段中有多少不同的数字 题目 ...
- CMake学习- 使用批处理设置编译环境
批处理-.bat cd /d "%~dp0" mkdir build mkdir install cd build ..\cmake37\bin\cmake.exe -D WIN3 ...
- WebGL的shader
WebGL的shader(着色器)有2种:vertexShader(定点着色器)和 fragmentShader(片段着色器) 顶点着色器:定义点的位置.大小 片元着色器:定义画出来的物体的材质(颜色 ...
- 解决node-sass无法下载的问题
本文链接:https://blog.csdn.net/qq383366204/article/details/86605960在国内用npm安装依赖的时候经常都会有各种奇怪的问题,个人强烈推荐用yar ...