牛刀小试——五分钟入门Spring Boot
wptr33 2025-03-12 21:12 20 浏览
万物皆可Hello World
在一个程序员的眼里,万物皆可Hello World。Spring Boot当然也不例外。下面一起来完成我们的第一个Spring Boot程序。
创建一个Web工程
新建项目:
在 首 次 运 行 Intellij IDEA 时 , 或 者 取 消 勾 选 Reopen projects onstartup(启动时重新打开项目)复选框时,你会看到如图3-1所示的界面,选择New Project选项。
在非首次运行Intellij IDEA时,你可以选择File→New→Project菜单命令来创建一个工程。
选择项目类型:
弹出如图所示的项目类型选择界面,首先选择左侧项目类型列表中的Spring Initializr 选 项 , 然 后 在 Project SDK 下 拉 列 表 中 选 择 1.8 javaversion“1.8.0_271”选项,单击Next按钮。
填写项目信息
弹出如图3-3所示的项目信息填写界面,其中Group对应pom文件中的groupId,Artifact对应pom文件中的artifactId,分别填入对应的内容即可。首先将项目类型设置为Maven,语言设置为Java,打包方式设置为Jar,然后在Java Version下拉列表中选择8选项,单击Next按钮。
选择依赖
接下来选择项目需要依赖的Jar包。如果你写过非Spring Boot的Java Web项目,那么回想一下,创建一个Java Web项目需要依赖哪些Jar包呢?好的,我知道你可能根本想不起来(或者说想不全)了,但这并不是你的错,因为Jar包实在太多、太琐碎了。值得庆幸的是,我们今天使用Spring Boot开发一个Web项目,根本不需要你记住依赖哪些Jar包。你只需要知道要开发的是一个Web工程即可。在Intellij IDEA的依赖选择界面中(见图3-4),你只需要勾选Spring Web复选框,然后单击Next按钮即可。
选择项目的保存路径
最后需要选择一下项目的保存路径,这里可以根据自己的习惯与喜好进行设置,并单击Finish按钮
项目创建完成后,你会看到如图3-6所示的项目结构。关于这个结构的细节,我们会在下一节进行详细讨论。
完成核心代码
经过上面的操作,我们就搭建好了一个Web工程的基础框架,距离完成我们的第一个Spring Boot程序只差最后一步了。接下来创建HelloController类并编写本例中仅有的hello方法代码。
创建HelloController类
在Intellij IDEA中新建一个类很简单,可以按照图3-7所示,单击工具栏中的Java Class按钮(如果你的Intellij IDEA中没有这个按钮,可以参考2.3.1 节 进 行 设 置 ) 来 创 建 一 个 HelloController 类 , 或 者 选 择File→New→Java Class菜单命令来创建,或者直接右击对应的package(如com.shuijing.boot)来创建
在New Java Class对话框中输入HelloController,并按Enter键,如图所示。
编写hello方法代码
在HelloController类中添加一个hello方法,具体代码如下:
关于@RestController和@GetMapping这两个注解的用途,会在下一章介绍。
运行并查看效果
经过以上步骤,我们的第一个Spring Boot程序就全部完成了。接下来需要验证一下这个程序是否可以正常运行。在Intellij IDEA中启动一个项目很简单,可以单击图3-9中任意一个向右的小箭头,也可以使用Shift+F10快捷键。
项目启动成功后,可以在Intellij IDEA的控制台看到如下日志:
接下来在浏览器中访问http://localhost:8080/hello,会看到页面中打印出如下内容:
运行结果如图所示。
经过上面的简单操作,我们就完成了一个基于Spring Boot的Hello World程序。如果你之前用过SSH或者SSM(如果没有,那么建议你去网上找一个教程体会一下),那么应当会更加深切地体会到Spring Boot的简洁与高效。
不知道你刚刚有没有意识到,在使用Spring Boot创建一个Web项目时,我们仅仅通过5个步骤就完成了!我们没有配置(甚至都没有见到)web.xml;没有配置启用注解;没有配置包扫描路径;没有配置视图解析;没有配置Tomcat……
对于以前创建一个Java Web项目时需要进行的所有配置,我们好像都没有做。难道现在技术进步了,不需要这些配置了吗?当然不是,当你觉得轻松的时候,一定是有人替你完成了这些配置。没错,一切繁杂且与业务无关的配置,都由Spring Boot帮我们默默地完成了。那么,Spring Boot是怎么做到的呢?其实核心思想就6个字——约定优于配置
Spring Boot的工程结构
接下来我们一起学习Spring Boot的工程结构。我们刚刚创建的工程结构如图所示。
如果你之前接触过Maven,那么应当非常熟悉这个结构,这就是一个标准的Maven工程结构。
Spring Boot之所以使用Maven的工程结构,是因为它们都遵循“约定优于配置”的设计哲学。
结构详解
下面我们来看每个文件/文件夹(目录)的作用:
从上面的结构中可以看出,工程根目录由4部分组成——target(目录)、gitignore(文件)、pom.xml(文件)和src(目录)。
我们知道,target是目标的意思,使用Maven打包后会将编译后的.class文件和依赖的Jar包,以及一些资源文件放到这个目录下。
gitignore文件用来配置那些不需要Git帮助我们进行版本控制的文件或目录,例如,Intellij IDEA产生的配置文件或者本地开发使用的applicationlocal.yml文件等。
pom.xml文件用来配置依赖的Jar包,帮助我们进行Jar包管理。我们会经常跟它打交道。
最后的src目录用来存放所有我们编写的Java源码文件、程序配置文件、资源文件等,是开发需要用到的主目录。
至此,我们对于Maven或者说Spring Boot的工程结构已经有了一个非常清晰的认识。但对于我们这种好学之人(不许笑),到这里是远远不够的。我们还想要了解为什么要将工程结构设计成这样。既要知其然,还要知其所以然。
结构分类
功能目录
target、gitignore和pom.xml都是偏工具属性的,主要是给Maven、Git用的,与开发人员的关系没有那么紧密。我们可以将其称为功能目录(文件)。
业务目录
真正跟开发人员息息相关的是src目录下的内容。开发人员平时操作最多的内容也是这个目录下的内容。我们可以清晰地看到,src目录有两个分支——main和test。这两个目录的用途很好理解,main用来存放业务逻辑主代码,而test则用来存放测试代码。而且我们可以很容易地发现它们两个内部的结构极其相似。因为test就是为main服务的,理论上讲,main中的每一个Java类(POJO类除外)在test中都有一个测试类,可以理解成main中的每个类都有一个“贴身侍卫”,用来护其周全。
再往下看,又分为dao、service、controller等目录,这体现了软件开发中最基本的分层思想,对应着数据层、业务逻辑层及Web控制层。
内容选自《SPringboot趣味实战课》侵权联系删除
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
如何将AI助手接入微信(打开ai手机助手)
-
Java面试必考问题:什么是乐观锁与悲观锁
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)