(一)基本概述
SpringBoot的出现,简化了Spring应用的初识化搭建、开发、部署及监控。其使用Maven的方式对Spring应用开发进行了封装和简化。
- 基本功能:无需手动管理依赖jar包的版本
Spring boot通过spring boot starter项目管理其提供的所有依赖的版本,当升级spring boot时,这些依赖的版本也会随之升级。个人无需指定版本号。
但是也可以自定义版本号覆盖springboot的默认值。每个版本的boot都有对应的base spring version,不建议明确地指定spring版本。
例如,使用maven时,只需简单的在pom中包含spring-boot-starter-web即引入了Spring MVC和Tomcat的依赖。
下面是Spring Boot在 org.springframework.boot 组下提供的一些Starters: - 简单入门
① 创建一个父模块
pom.xml
<groupId>cn.lzj.springboot</groupId>
<artifactId>springboot_parent</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>springboot_01_hello</module>
</modules>
<!-- 知识点:dependencyManagement
使用dependencyManagement可以统一管理项目的版本号,确保应用的各个项目的依赖和版本一致,
不用每个模块项目都弄一个版本号,不利于管理,当需要变更版本号的时候只需要在父类容器里更新,
不需要任何一个子项目的修改;如果某个子项目需要另外一个特殊的版本号时,
只需要在自己的模块dependencies中声明一个版本号即可。
子类就会使用子类声明的版本号,不继承于父类版本号。
与dependencies区别:
1)Dependencies相对于dependencyManagement,所有生命在dependencies里的依赖都会自动引入,并默认被所有的子项目继承。
2)dependencyManagement里只是声明依赖,并不自动实现引入,因此子项目需要显示的声明需要用的依赖。
如果不在子项目中声明依赖,是不会从父项目中继承下来的;
只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,
并且version和scope都读取自父pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。
-->
<dependencyManagement>
<dependencies>
<!--在父pom内引入,springboot的依赖管理-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.0.5.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
② 创建一个子模块
pom.xml
<parent>
<artifactId>springboot_parent</artifactId>
<groupId>cn.lzj.springboot</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<!--
spring boot 父节点依赖,引入这个之后相关的引入就不需要添加version配置,spring boot会自动选择最合适的版本进行添加。
-->
<!--<parent>-->
<!--<groupId>org.springframework.boot</groupId>-->
<!--<artifactId>spring-boot-starter-parent</artifactId>-->
<!--<version>2.0.5.RELEASE</version>-->
<!--</parent>-->
<modelVersion>4.0.0</modelVersion>
<artifactId>springboot_01_hello</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--热部署依赖包-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
<scope>true</scope>
</dependency>
</dependencies>
<build>
<!--热部署的插件-->
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<!--fork : 如果没有该项配置,可能devtools不会起作用,即应用不会restart -->
<fork>true</fork>
</configuration>
</plugin>
</plugins>
</build>
③ 创建一个controller
@RestController
//@Controller
public class HelloController {
@RequestMapping("/hello1")
// @ResponseBody //直接作为字符串返回而不是页面地址
public String sayHello(String name){
return name +" hello,do more , get more ";
}
@RequestMapping("/hello2")
// @ResponseBody //直接作为字符串返回而不是页面地址
public String sayHello2(String name){
return name +" hello, This moment , the world has nothing to do with me!";
}
}
④ 创建SpringBoot的应用
@SpringBootApplication//标识该应用为springboot的应用
public class HelloApplication {
//传统方式如何开发springweb项目?
// 1 启动外部tomcat
// 2 根据web.xml中配置信息初始化一个spring容器(applicationContext)
// 3 做了一些常规配置后还会根据扫描包路径扫描一些bean(dao,service,controller)
//通过主方法,启动Springboot的应用
public static void main(String[] args) {
// 1 启动了内置tomcat
// 2 初始化spring容器
// 3 自动配置(springmvc),扫描加了@SpringBootApplication类的当前包及其子子孙孙里面所有spring注解(@Repository @service @controller)
//并且把扫描到的类纳入Spring管理
SpringApplication.run(HelloApplication.class);
}
}
到此,SpringBoot的入门程序就已经实现了,运行主方法就可以启动SpringBoot内置的tomcat,在浏览器内输入对应的路径进行访问