Spring Boot框架入门教程(快速学习版)
Spring Boot教程BooTWiki.COM
Spring Boot是Pivotal(关键性的)团队在Spring的基础上提供的一套全新的开源框架,其目的是为了简化Spring应用的搭建和开发过程。Spring Boot去除了大量的XML配置文件,简化了复杂的依赖管理。
Spring Boot具有Spring一切优秀特性,Spring能做的事,Spring Boot都可以做,而且使用更加简单,功能更加丰富,性能更加稳定而健壮。随着近些年来微服务技术的流行,Spring Boot也成了时下炙手可热的技术。
Spring Boot集成了大量常用的第三方库配置,Spring Boot应用中这些第三方库几乎可以是零配置的开箱即用(out-of-the-box),大部分的 Spring Boot应用都只需要非常少量的配置代码(基于Java的配置),开发者能够更加专注于业务逻辑。
简化Spring应用开发的一个框架;
整个Spring技术栈的一个大整合;
J2EE开发的一站式解决方案;
众所周知Spring应用需要进行大量的配置,各种XML配置和注解配置让人眼花缭乱,且极容易出错,因此Spring一度被称为“配置地狱”。
为了简化Spring应用的搭建和开发过程,Pivotal团队在Spring基础上提供了一套全新的开源的框架,它就是Spring Boot。
Spring Boot具有Spring一切优秀特性,Spring能做的事,Spring Boot都可以做,而且使用更加简单,功能更加丰富,性能更加稳定而健壮。随着近些年来微服务技术的流行,Spring Boot也成为了时下炙手可热的技术。
Spring Boot提供了大量开箱即用(out-of-the-box)的依赖模块,例如 spring-boot-starter-redis、spring-boot-starter-data-mongodb和spring-boot-starter-data-elasticsearch等。这些依赖模块为Spring Boot应用提供了大量的自动配置,使得Spring Boot应用只需要非常少量的配置甚至零配置,便可以运行起来,让开发人员从Spring的“配置地狱”中解放出来,有更多的精力专注于业务逻辑的开发。
Spring Boot具有以下特点:
(1)独立运行的Spring项目
Spring Boot可以以jar包的形式独立运行,Spring Boot项目只需通过命令“ java–jar xx.jar” 即可运行。
(2)内嵌Servlet容器
Spring Boot使用嵌入式的Servlet容器(例如 Tomcat、Jetty 或者 Undertow 等),应用无需打成WAR包 。
(3)提供starter简化Maven配置
Spring Boot提供了一系列的“starter”项目对象模型(POMS)来简化Maven配置。
(4)提供了大量的自动配置
Spring Boot提供了大量的默认自动配置,来简化项目的开发,开发人员也通过配置文件修改默认配置。
(5)自带应用监控
Spring Boot可以对正在运行的项目提供监控。
(6)无代码生成和xml配置
Spring Boot不需要任何xml配置即可实现Spring的所有配置。
一、单体应用
一个单体应用程序把它所有的功能放在一个单一进程中。
二、微服务
2014年,Martin Fowler
微服务:架构风格
一个应用应该是一组小型服务;可以通过HTTP的方式进行互通。
每一个功能元素最终都是一个可独立替换和独立升级的软件单元。
使用IDEA创建一个Spring Boot项目。
Spring Boot 2.x
JDK 8.0 及以上版本
Maven 3.x
IntelliJ IDEA 14.0 以上
Intellij IDEA 一般可以通过两种方式创建 Spring Boot 项目:
方式一:使用Maven创建。
方式二:使用Spring Initializr创建。
本处使用Maven方式创建。
一、使用IntelliJ IDEA创建一个名称为helloworld的Maven项目。
D:\CODEjava\helloworld
二、在该Maven项目的pom.xml中添加以下配置,导入Spring Boot相关的依赖。
三、在net.biancheng.www包下,创建一个名为helloWorldApplication主程序,用来启动Spring Boot应用,代码如下。
四、为了能比较的清楚的看到效果,我们在net.biancheng.www包下又创建一个controller包,并在该包内创建一个名为HelloController的 Controller,代码如下。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>helloworld</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.5</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
</project>
package net.biancheng.www;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class helloWorldApplication {
public static void main(String[] args) {
SpringApplication.run(helloWorldApplication.class, args);
}
}
Spring Boot Application的入口点是包含@SpringBootApplication注释的类。该类应具有运行Spring Boot应用程序的主要方法。 @SpringBootApplication注释包括自动配置,组件扫描和Spring Boot配置。
如果将@SpringBootApplication批注添加到类中,则无需添加@EnableAutoConfiguration,@ComponentScan和@SpringBootConfiguration批注。@SpringBootApplication注释包括所有其他注释。
package net.biancheng.www.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
@ResponseBody
@RequestMapping("/hello")
public String hello() {
return "Hello World!";
}
}
默认情况下,Spring Boot项目会创建一个名为***Application的主程序启动类 ,该类中使用了一个组合注解@SpringBootApplication,用来开启Spring Boot的自动配置,另外该启动类中包含一个main()方法,用来启动该项目。
直接运行启动类HelloworldApplication中的main()方法,便可以启动该项目,结果如下图。

注意:Spring Boot内部集成了Tomcat,不需要人为手动配置Tomcat,开发者只需要关注具体的业务逻辑即可。
重启Spring Boot项目,然后在地址栏访问"http://localhost:8080/hello"。

传统的Spring项目想要运行,不仅需要导入各种依赖,还要对各种XML配置文件进行配置,十分繁琐,但Spring Boot项目在创建完成后,即使不编写任何代码,不进行任何配置也能够直接运行,这都要归功于Spring Boot的starter机制。
所有Spring Boot启动程序都遵循相同的命名模式
spring-boot-starter-*,其中*表示它是应用程序的一种类型。
(1)spring-boot-starter-actuator依赖关系用于监视和管理应用程序。
(2)spring-boot-starter-security依赖项用于Spring Security。
(3)spring-boot-starter-web依赖项用于编写Rest端点。
(4)spring-boot-starter-thymeleaf依赖项用于创建Web应用程序。
(5)spring-boot-starter-test依赖项用于编写测试用例。
Spring Boot将日常企业应用研发中的各种场景都抽取出来,做成一个个的starter(启动器),starter中整合了该场景下各种可能用到的依赖,用户只需要在Maven中引入starter依赖,Spring Boot就能自动扫描到要加载的信息并启动相应的默认配置。starter提供了大量的自动配置,让用户摆脱了处理各种依赖和配置的困扰。所有这些starter都遵循着约定成俗的默认配置,并允许用户调整这些配置,即遵循“约定大于配置”的原则。
并不是所有的starter都是由Spring Boot官方提供的,也有部分starter是第三方技术厂商提供的,例如druid-spring-boot-starter和mybatis-spring-boot-starter等等。当然也存在个别第三方技术,Spring Boot官方没提供starter,第三方技术厂商也没有提供starter。
以spring-boot-starter-web为例,它能够为提供Web开发场景所需要的几乎所有依赖,因此在使用Spring Boot开发Web项目时,只需要引入该Starter即可,而不需要额外导入Web服务器和其他的Web依赖。
在pom.xml中引入spring-boot-starter-web,示例代码如下。
<!--SpringBoot父项目依赖管理-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.5</version>
<relativePath/>
</parent>
....
<dependencies>
<!--导入 spring-boot-starter-web-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
...
</dependencies>
在该项目中执行以下mvn命令查看器依赖树。
mvn dependency:tree

从以上结果中,我们可以看到Spring Boot导入了springframework、logging、jackson以及Tomcat等依赖,而这些正是我们在开发Web项目时所需要的。
您可能会发现一个问题,即在以上pom.xml的配置中,引入依赖spring-boot-starter-web时,并没有指明其版本(version),但在依赖树中,我们却看到所有的依赖都具有版本信息,那么这些版本信息是在哪里控制的呢?其实,这些版本信息是由spring-boot-starter-parent(版本仲裁中心)统一控制的。
spring-boot-starter-parent是所有Spring Boot项目的父级依赖,它被称为Spring Boot的版本仲裁中心,可以对项目内的部分常用依赖进行统一管理。
<!--SpringBoot父项目依赖管理-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.5</version>
<relativePath/>
</parent>
Spring Boot项目可以通过继承spring-boot-starter-parent来获得一些合理的默认配置,它主要提供了以下特性:
(1)默认JDK版本(Java 8)。
(2)默认字符集(UTF-8)。
(3)依赖管理功能。
(4)资源过滤。
(5)默认插件配置。
(6)识别application.properties和application.yml类型的配置文件。
一、查看spring-boot-starter- parent的底层代码,可以发现其有一个父级依赖spring-boot-dependencies。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.4.5</version>
</parent>
二、spring-boot-dependencies的底层代码如下。
<modelVersion>4.0.0</modelVersion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.4.5</version>
<packaging>pom</packaging>
....
<properties>
<activemq.version>5.16.1</activemq.version>
<antlr2.version>2.7.7</antlr2.version>
<appengine-sdk.version>1.9.88</appengine-sdk.version>
<artemis.version>2.15.0</artemis.version>
<aspectj.version>1.9.6</aspectj.version>
<assertj.version>3.18.1</assertj.version>
<atomikos.version>4.0.6</atomikos.version>
....
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-amqp</artifactId>
<version>${activemq.version}</version>
</dependency>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-blueprint</artifactId>
<version>${activemq.version}</version>
</dependency>
...
</dependencies>
</dependencyManagement>
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>${build-helper-maven-plugin.version}</version>
</plugin>
<plugin>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-maven-plugin</artifactId>
<version>${flyway.version}</version>
</plugin>
...
</plugins>
</pluginManagement>
</build>
以上配置中,部分元素说明如下:
(1)dependencyManagement :负责管理依赖;
(2)pluginManagement:负责管理插件;
(3)properties:负责定义依赖或插件的版本号。
spring-boot-dependencies通过dependencyManagement 、pluginManagement和properties等元素对一些常用技术框架的依赖或插件进行了统一版本管理,例如Activemq、Spring、Tomcat等。
Spring Boot Application的入口点是包含@SpringBootApplication注释的类。该类应具有运行Spring Boot应用程序的主要方法。 @SpringBootApplication注释包括自动配置,组件扫描和Spring Boot配置。
如果将@SpringBootApplication批注添加到类中,则无需添加@EnableAutoConfiguration,@ComponentScan和@SpringBootConfiguration批注。@SpringBootApplication注释包括所有其他注释。
请注意以下代码以便更好地理解
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
要在Spring Boot Application主类文件本身中编写一个简单的Hello World Rest端点,请按照以下步骤操作:
(1)首先,在类的顶部添加@SpringBootApplication和@Controller注释。
(2)使用@ResponseBody和@RequestMapping注释编写Request URI方法。
(3)Request URI方法应该返回Hello World!123字符串。
package net.biancheng.www;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@SpringBootApplication
@Controller
public class helloWorldApplication {
public static void main(String[] args) {
SpringApplication.run(helloWorldApplication.class, args);
}
@ResponseBody
@RequestMapping("/hello")
public String hello() {
return "Hello World!123";
}
}
在IDEA中写application.properties没有自动提示原因之一。
编辑application.properties文件时需要添加Spring Boot插件并且打开。
解决办法如下:
1.点击file选择Settings
2.点击Plugins
3.选择Marketplace并搜索:“Spring Boot”并点击Install安装

记得一定要把Spring Boot后面的方框打上勾,然后提示重启IDEA。
最后:查看application.properties文件已经变成一片绿叶子了。
注意:社区版本的IDEA无法安装Spring Boot插件。
因为IDEA是社区版,所以不能安装Spring Boot插件,选择安装Spring Boot Assistant,然后就可以用application.yml识别配置内容,最后设置到application.properties。
1、SpringBoot默认配置文件application.properties,通过键值对配置对应属性。
# 服务器端口配置
server.port=80
# 修改banner,logo
spring.main.banner-mode=off
# 修改日志级别
logging.level.root=INFO
2、Spring Boot中导入对应starter后,提供对应配置属性。
3、书写Spring Boot配置采用关键字+提示形式书写。
1、application.properties(传统格式/默认格式,优先级最高)
server.port=80
2、application.yml(主流格式)
server:
port: 81
3、application.yaml(优先级最低)
server:
port: 82
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我想用ruby编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我