查看“Springboot”的源代码
←
Springboot
跳到导航
跳到搜索
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
==Spring Boot 概述== ===Spring Boot 是什么===   Spring Boot 是由 Pivotal 团队提供的全新框架,其设计目的是用来简化 Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。Spring Boot采用约定优于配置的方式,大量的减少了配置文件的使用。      一般我们把Spring Boot称为搭建程序的 脚手架 或者说是 便捷搭建基于Spring的工程脚手架 。主要的作用就是帮助开发人员快速构建Spring项目,并且尽可能的减少一切xml配置,做到开箱即用,快速上手,让开发人员关注业务而非配置。Spring Boot简化了基于Spring的应用开发,只需要“run” 就能创建一个独立的、生产级别的Spring应用。Spring Boot为Spring平台及第三方库提供了开箱即用的设置,这样我们就可以简单的开始。多数Spring Boot应用只需要很少的Spring配置。 Spring Boot 的特性 *创建独立的Spring应用 *直接嵌入 Tomcat、Jetty 或Undertow(无需部署 WAR 文件) *提供固定"启动器"依赖关系,以简化构建配置 *尽可能自动配置Spring和第三方库 *提供生产就绪型功能,如指标、运行状况检查和外部配置 *绝对没有代码生成,也没有 XML 配置要求 ===为什么要用Spring Boot=== Java(Spring)一直被人诟病的一点就是臃肿、麻烦,主要原因是以下两点: *复杂的配置 *混乱的依赖管理   通过上小节Spring Boot的特性,我们可以看到,Spring Boot就是用来解决这些问题的。自动配置,可以节省我们大量的配置问题,Spring Boot为Spring和其他有需要的第三方依赖提供了默认配置,我们甚至可以不做任何配置就可以启动和运行项目。依赖关系,Spring Boot通过starter引入第三方依赖,其中的所有依赖关系都是经过测试和验证的,再加上Maven等依赖管理工具避免了依赖冲突。 ==Spring Boot 快速启动== 启动一个提供Http请求的Restful的服务接口,请求地址为http://localhost:8080/hello 返回 Hello Spring Boot! 环境准备: *JDK1.8.X *Maven 3.6.X *Eclipse 4.x/STS 4.x(Spring Tools Suite)/Idea *Spring Boot 2.3.X *Spring 5 ===创建项目工程=== 1.创建一个Spring Starter Project 2.填写相关信息 Name: HelloSpringBoot Java Version:8 Group: com.kayak Package: com.kayak.springboot.demo 3.选择版本,配置starter(启动器) Spring Boot Version: 2.3.X Dependencies: Spring Web 完整的pom文件 <blockquote> <?xml version="1.0" encoding="UTF-8"?> <project xmlns="<nowiki>http://maven.apache.org/POM/4.0.0</nowiki>" xmlns:xsi="<nowiki>http://www.w3.org/2001/XMLSchema-instance</nowiki>" xsi:schemaLocation="<nowiki>http://maven.apache.org/POM/4.0.0</nowiki> <nowiki>https://maven.apache.org/xsd/maven-4.0.0.xsd</nowiki>"> <modelVersion>4.0.0</modelVersion> <!-- spring-boot-starter-parent 对各种常用依赖的版本进行了管理,使用它作为父工程就不用关心依赖的版本问题 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.3.RELEASE</version> <relativePath /> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>HelloSpringBoot</artifactId> <version>0.0.1-SNAPSHOT</version> <name>HelloSpringBoot</name> <description>Demo project for Spring Boot</description> <properties> <!-- 依赖的JDK版本,如果没有需求则不需要添加 --> <java.version>1.8</java.version> </properties> <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> <exclusions> <exclusion> <groupId>org.junit.vintage</groupId> <artifactId>junit-vintage-engine</artifactId> </exclusion> </exclusions> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project> </blockquote> ===启动类=== Spring Boot 项目通过main函数即可启动 <blockquote> package com.kayak.springboot.demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class HelloSpringBootApplication { public static void main(String[] args) { SpringApplication.run(HelloSpringBootApplication.class, args); } } </blockquote> ===编写 Controller=== <blockquote> package com.kayak.springboot.demo.controller; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { @GetMapping("/hello") public String hello() { return "Hello Spring Boot!"; } } </blockquote> ===使用启动类启动运行=== <blockquote> 2020-09-16 16:48:10.037 INFO 17152 --- [ main] c.k.s.demo.HelloSpringBootApplication : Starting HelloSpringBootApplication on DESKTOP-R2M87Q2 with PID 17152 (D:\work2\HelloSpringBoot\target\classes started by younge in D:\work2\HelloSpringBoot) 2020-09-16 16:48:10.040 INFO 17152 --- [ main] c.k.s.demo.HelloSpringBootApplication : No active profile set, falling back to default profiles: default 2020-09-16 16:48:12.897 INFO 17152 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat initialized with port(s): 8080 (http) 2020-09-16 16:48:12.917 INFO 17152 --- [ main] o.apache.catalina.core.StandardService : Starting service [Tomcat] 2020-09-16 16:48:12.918 INFO 17152 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet engine: [Apache Tomcat/9.0.37] 2020-09-16 16:48:13.058 INFO 17152 --- [ main] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext 2020-09-16 16:48:13.059 INFO 17152 --- [ main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 2907 ms 2020-09-16 16:48:13.413 INFO 17152 --- [ main] o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService 'applicationTaskExecutor' 2020-09-16 16:48:13.763 INFO 17152 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path '' 2020-09-16 16:48:13.781 INFO 17152 --- [ main] c.k.s.demo.HelloSpringBootApplication : Started HelloSpringBootApplication in 4.381 seconds (JVM running for 5.095) 2020-09-16 16:48:27.398 INFO 17152 --- [nio-8080-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring DispatcherServlet 'dispatcherServlet' 2020-09-16 16:48:27.398 INFO 17152 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet : Initializing Servlet 'dispatcherServlet' 2020-09-16 16:48:27.411 INFO 17152 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet : Completed initialization in 13 ms </blockquote> 1. banner:Spring Boot在启动的时候会有一个默认的启动图标,而且是可以自定义的 https://www.jianshu.com/p/bfbcabc4af1d *启动类Main方法里面配置: SpringApplication::SetBanner(Banner)、SpringApplication::SetBannerMode(Mode) *src\resources\banner.txt、banner.png/jpg: <blockquote> #这个是MANIFEST.MF文件中的版本号 ${application.version} #这个是上面的的版本号前面加v后上括号 ${application.formatted-version} #这个是springboot的版本号 ${spring-boot.version} #这个是springboot的版本号 ${spring-boot.formatted-version} #枚举类AnsiColor这个可以替换显示的颜色 ${AnsiColor.***} </blockquote> * application.properties: spring.main.show-banner=false * 重写接口Banner实现 2. 默认profile为default 3. 默认容器为Tomcat 修改默认容器 1. 在starter-web的依赖里排除tomcat 2. 添加响应的容器starter依赖 <blockquote> java <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency> </blockquote> 4. Tomcat默认端口为8080 <blockquote>properties # 配置端口 server.port=9080 </blockquote> 5. SpringMVC的项目路径是“” <blockquote>properties # 配置上下文路径 server.servlet.context-path=/yy </blockquote> ===使用浏览器访问测试=== http://localhost:8080/hello ===创建可运行的Jar=== 我们通过创建一个完全独立的可执行 jar 文件来完成我们的示例,该文件可以在生产环境中运行。可执行 jar(有时称为"Fat jar")是包含编译类以及代码需要运行的所有 jar 依赖项的存档。 Java 不提供加载嵌套 jar 文件的标准方法(jar 文件本身包含在 jar 中)。如果您想要分发自包含的应用程序,这可能有问题。 为了解决这个问题,许多开发人员使用"uber"jar。Uber jar 将所有应用程序依赖项的所有类打包到单个存档中。此方法的问题在于,很难看到应用程序中的库。如果在多个 jar 中使用相同的文件名(但内容不同),也可能存在问题。 Spring Boot 采用不同的方法,让您直接嵌套 jar。 若要创建可执行 jar,我们需要将 spring-boot-maven-plugin添加到 我们的pom.xml 。 <blockquote><build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </blockquote>然后我们就可以用maven打包了,打包成功之后我们会发现生成了两个文件,一个就是我们的“胖jar”,另一个会有“original”后缀,也就是原始的普通jar,是不能独立运行的。而“胖jar"就是可以独立运行的jar,如果我们把他解压开就会发现里面包含了所有需要依赖的jar文件。 BOOT-INF:主要是我们项目的东西 META-INF:工程描述文件 org:SpringBoot执行嵌套jar的方法 然后我们只需要使用 java -jar 就可以了。 可以将 Spring Boot 应用程序部署到各种云平台、容器映像(如 Docker)或虚拟/真实计算机 ===关于starter=== starter,我们也称为启动器或者起步依赖,是Spring Boot中非常重要的一个概念,包括自动装配也都会用到它,Spring Boot提供了诸如web、data、test、sercuity等等应用级别的starter,另外还提供了下面两类: Spring Boot production starters :spring-boot-starter-actuator 它提供生产就绪功能,帮助您监控和管理应用程序 Spring Boot technical starters :spring-boot-starter-jetty、spring-boot-starter-log4j2、spring-boot-starter-logging、spring-boot-starter-reactor-netty、spring-boot-starter-tomcat、spring-boot-starter-undertow ===关于热部署=== Spring Boot也是普通的java项目,所以JVM的热部署也应该是开箱即用的,自然也有一些更完善的实现。另外spring-boot-devtools也包含对应用快速重启的支持。打包的存档默认是不包含开发工具开发人员工具的,也就是说生产应用程序中自动禁用了该工具。 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional><!-- 表示两个项目之间依赖不传递 --> </dependency> ===执行器:生产就绪功能=== 添加spring-boot-starter-actuator依赖,即可启用生产就绪功能 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> <optional>true</optional> </dependency> actuator,我们称为执行器,提供EndPoints,我们称为断点,可让您监控应用程序并与应用程序进行交互。Spring Boot 包括许多内置端点,并允许您添加自己的端点。可以通过 HTTP 或 JMX 启用或禁用每个单独的终结点并公开(可远程访问),通常在HTTP上,映射的路径为为/actuator加上端点名,例如默认情况下HTTP公开了/actuator/health和/actuator/info(分别用于显示应用程序运行状况信息和显示任意应用程序信息)。 /actuator映射称为”发现页“,该页包含指向所有终结点的链接 ==Spring Boot的配置== Spring Boot 可以快速的实现SpringMVC的项目,免配置、快捷、高效!如果需要进行配置设置呢? ===Spring Boot中的Java配置=== Java配置主要靠一些Java类和注解来完成,常见的注解包括: * @Configuration: 声明一个类作为配置类,代替xml文件 * @Bean: 声明一个发放,讲方法的返回值加入Bean容器(IOC容器),代替<bean>标签 * @ConfigurationProperties: 将配置文件中的健:值自动映射注入Java Bean * @value: 属性注入 * @propertySource: 加载指定配置文件 * @ImportResource 导入Spring 配置文件 ===Spring Boot属性注入=== ====Spring Boot的属性文件==== Spring Boot默认的属性文件名称为:application.properties或者application.yml ====属性的注入==== =====@Value注入===== 直接使用 @Value (xxx) 注解就可以直接为某个属性注入全局配置文件中的值 @Value(“#{}”):表示 SpEl表达式。 @Value(“${xxx}”):表示从配置文件中取值,如果 "xxx" key 不存在,则启动时报错:Injection of autowired dependencies failed @Value(“${xxx:yyy}”):从配置文件中取值,如果 "xxx" key 不存在,则使用默认值 "yyy",否则启动会报错。 =====@ConfigurationProperties赋值===== 可以将全局配置文件中的键-值自动映射注入 Java Bean 中,Java bean 的属性必须提供 setter 方法才能注入值。 @ConfigurationProperties 可以标注在类、接口、枚举、注解、方法上 所在的类需要是 Spring 组件(@Component ) prefix 属性:用于将配置文件中指定的 key 下的所有属性与本类属性进行一一映射注入值,如果配置文件中不存在此 key,则不会为POJO注入值。如 prefix="user"、prefix="app.user" 。 ignoreInvalidFields 属性:是否忽略无效的字段,默认为 false 表示不忽略。配置的属性值类型错误,无法强转的字段就是无效字段,如果有无效字段且此属性为 false,则启动报错,无法正常启动应用,为 true 时则会忽略注入。 配置文件中没有为 java bean 配置相应的属性值,则不会注入值,java bean 属性仍然使用自己的默认值,不会影响程序启动。 <blockquote> /** *客户实体. * *<p> *包含一些基本属性和一个账户属性。@ConfigurationProperties 告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定;<br /> *prefix = "customer" 表示将配置文件中key为customer的下面所有的属性与本类属性进行一一映射注入值,如果配置文件中不存在"customer"的key,则不会注入值,属性值仍然为默认值;<br /> *ignoreInvalidFields = true 表示忽略配置文件中的无效字段 注解@Component 将本类标识为一个Spring *组件,因为只有是容器中的组件,容器才会为@ConfigurationProperties提供此注入功能 *<p /> * *@author younge *@date 2020/09/18 */ @Component<br /> @ConfigurationProperties(prefix = "customer", ignoreInvalidFields = true)<br /> public class Customer {<br /> private Integer id;<br /> private String name;<br /> private Integer age;<br /> private Account account;<br /> ...<br /> }<br /> </blockquote> <blockquote> *application.properties内容 customer.id:1<br /> customer.name:Younge<br /> customer.age:35<br /> customer.account.accountNo:s1111<br /> customer.account.amount:FF9999.99<br /> </blockquote> <blockquote> @RestController<br /> public class CustomerController {<br /> // 必须使用@Resource、@Autowired 注入对象才能获取到它注入的属性值,直接 new 对象是没有注入的默认值的<br /> @Autowired<br /> private Customer customer;<br /> @GetMapping(value = "/customer")<br /> private String customer() {<br /> return customer.toString();<br /> }<br /> }<br /> </blockquote> ====@PropertySource导入配置文件==== Spring Boot默认的全局配置文件“application.properties”或者“application.yml”,当应用比较大的时候,如果所有的内容都当在一个配置文件中,就会显得比较臃肿,同时也不太好理解和维护,此时可以将一个文件拆分为多个,使用 @PropertySource 注解加载指定的配置文件。 =====加载properties文件===== <blockquote> @Component<br/> @ConfigurationProperties(prefix = "customer", ignoreInvalidFields = true)<br/> @PropertySource(value = {"classpath:customer.properties"})<br/> public class Customer {<br/> <br> private Integer id;<br/> private String name;<br/> private Integer age;<br/> private Account account;<br/> ...<br/> }<br/> 配置文件内容:<br/> customer.properties<br/> customer:id:1<br/> customer.name:Younge<br/> customer.age:35<br/> customer.account.accountNo:s1111<br/> customer.account.amount:9999.99<br/> </blockquote> ====加载Yaml文件==== 创建PropertySourceFactory类 <blockquote> /**<br> * 用于@PropertySource加载yaml文件<br> * <br> * @author younge<br> * @date 2020/09/18<br> */<br> public class PropertySourceFactory extends DefaultPropertySourceFactory {<br> @Override<br> public PropertySource<?> createPropertySource(String name, EncodedResource resource) throws IOException {<br> if (resource == null) {<br> return super.createPropertySource(name, resource);<br> }<br> List<PropertySource<?>> sources =<br> new YamlPropertySourceLoader().load(resource.getResource().getFilename(), resource.getResource());<br> return sources.get(0);<br> }<br> }<br> </blockquote> 在上面 properties 的基础上修改如下<br> @PropertySource(value = {"classpath:customer.yml"}, factory = PropertySourceFactory.class) ====@ImportResource 导入Spring 配置文件==== 1、@ImportResource 注解用来导入 Spring 的配置文件,如核心配置文件 "beans.xml",从而让配置文件里面的内容生效;<br /> 2、如果应用中仍然想采用以前 xml 文件的配置方式,如 "beans.xml" ,则使用 “@ImportResource” 注解轻松搞定。<br /> 3、将 @ImportResource 标注在一个配置类上,通常直接放置在应用启动类上,和 @SpringBootApplication 一起即可。<br /> 4、然后就可以在类路径下提供原始的 beans.xml 配置文件:<br /> 5、启动应用控制台会打印:loading XML bean definitions from class path resource [beans. xml] 表示加载成功。<br /> ===多个配置文件=== 当项目有多个配置文件的时候,可以用application-***命名,在application.yml/application.properties中配置项目使用激活这些配置文件即可。多个文件名只需要写applicaiton-之后的名称,多个文件名之间用,分割 spring: profiles: active: pro,def 这种用法通常也用作多个环境配置文件的切换 application.properties application-pro.properties application-dev.properties application-sit.properties application-uat.properties log4j.xml log4j-pro.xml log4j-dev.xml log4j-sit.xml log4j-uat.xml
返回至“
Springboot
”。
导航菜单
个人工具
登录
名字空间
页面
讨论
变体
视图
阅读
查看源代码
查看历史
更多
搜索
导航
-==扬==-
-==帆==-
-==起==-
-==航==-
最近更改
随机页面
MediaWiki帮助
工具
链入页面
相关更改
特殊页面
页面信息