spring boot主要目的是提升开发效率,开发人员不需要像以前开发项目时写一大堆xml配置以及管理一大堆jar包及jar包版本。
spring boot 解决思路是对外提供一系列的starter供开发人员选择。而每个starter就集成了一个具体完整功能需要的所有jar包。
比如web项目,则你只要在maven中加入:
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
这样就引入web所需的jar包。
对应引入的jar包如下:
开发一个简单基于spring boot的web例子,步骤如下:
一.porm创建
主要是继承spring boot的parent,及加入spring-boot-starter-web如下:
<?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>test</groupId>
<artifactId>springboot</artifactId>
<version>1.0</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.1.10.RELEASE</version>
</parent>
<!-- Additional lines to be added here... -->
<!-- (you don't need this if you are using a .RELEASE version) -->
<repositories>
<repository>
<id>spring-snapshots</id>
<url>http://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
<repository>
<id>spring-milestones</id>
<url>http://repo.spring.io/milestone</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-snapshots</id>
<url>http://repo.spring.io/snapshot</url>
</pluginRepository>
<pluginRepository>
<id>spring-milestones</id>
<url>http://repo.spring.io/milestone</url>
</pluginRepository>
</pluginRepositories>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
二.创建配置运行类
spring boot可以基于注解形式进行启动。启动一个spring web项目需要创建spring容器及servlet容器。
一个web项目无非两种情形:
1.servlet容器内部包含spring容器,这也是传统的web项目。
2.spring容器包含内嵌servlet容器
这里spring boot是属于第2种。
我们创建一个启动类,代码如下:
这个类package是:test.springboot
@ComponentScan
@EnableAutoConfiguration
public class Example {
@RequestMapping("/")
String home() {
return "Hello World!";
}
public static void main(String[] args) throws Exception {
SpringApplication.run(Example.class, args);
}
}
创建IndexController
pacakage是:test.springboot.controller
代码如下:
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class IndexController {
@RequestMapping("/")
String home() {
return "Hello World!";
}
}
@EnableAutoConfiguration,这个注解主要是用来根据引入的jar包来实例化不同实现类,比如引入了tomat-embedded.jar则实例化TomcatEmbeddedServletContainerFactory。
@RestController及@RequestMapping是spring mvc注解。分别代表这是一个controller以及对应home方法的请求url是 /。
@ComponentScan代表扫描注解类。
核心是main方法中,SpringApplication的run方法,这里以 Example为source参数(代表启动入口类,扫描注解类会以这个启动类所在package进行扫描)。
run方法基本做了以下事情:
创建spring容器,创建内嵌tomcat容器,扫描注解类实例化所有bean实例并放入spring。
至此一个最简单的web项目就已经好了,访问localhost:8080可以看到效果。
注:EnableAutoConfiguration会引入EnableAutoConfigurationImportSelector及AutoConfigurationPackages。EnableAutoConfigurationImportSelector会去查找META-INF/spring.factories文件所标识的类,然后实例化。
例如:EmbeddedServletContainerAutoConfiguration,这也是一个有@configuration注解的类,会被实例化,内部最终会实例化TomcatEmbeddedServletContainerFactory。