前言
随着各种开源的第三方的组件爆发式增长,java的开发显得越来越笨重:繁多的配置,低下的开发效率,复杂的部署流程以及第三方技术集成难度大。
在上述环境下,Spring Boot应运而生。它使用"习惯优于配置"(项目中存在大量的配置,此外还内置一个习惯性的配置,让你无需手动进行配置) 的理念让你的项目快速运行起来。使用Spring boot很容易创建一个独立运行(运行jar,内置servlet容器)、准生产级别的基于Spring框架的项目,使用spring boot你可以不用或者很少的spring配置。
spring boot的优缺点
优点:
快速构建项目
对主流开发框架的无配置集成
项目可独立运行,无须依赖外部servlet容器
提供运行时的应用监控
极大的提高了开发部署效率
与云计算的天然集成
缺点:
书籍文档较少且不够深入
由于大部分配置在类里面完成的,所以损失了一定的可维护的便利性
所以spring boot特别适合中小型项目。
Hello World程序开发
1. 设置spring boot的parent
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.2.RELEASE</version>
</parent>
说明:Spring boot的项目必须要将parent设置为spring boot的parent,该parent包含了大量默认的配置,大大简化了我们的开发。
而且引入以后在申明其它dependency的时候就不需要version了,后面可以看到。
2. 导入spring boot的web支持
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
3. 添加spring boot的maven插件
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
当然,如果你不想用maven命令运行,也可以不用配置该插件
pom文件完整版
<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>com.wx</groupId>
<artifactId>springboot01</artifactId>
<version>0.0.1-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.2.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
<!-- java编译插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<!-- 如果你不想用maven命令运行spring boot可以不用作此配置 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
4. 编写Hello World程序
package com.wx.controlers;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@SpringBootApplication
//@Configuration //因为@SpringBootApplication包含了Configuration,所以这里可以省略
public class HelloApp {
@RequestMapping("hello")
@ResponseBody
public String hello(){
return "Hello";
}
public static void main(String[] args) {
SpringApplication.run(HelloApp.class, args);
}
}
代码说明:
(1)@SpringBootApplication:Spring Boot项目的核心注解,主要目的是开启自动配置。
(2)@Configuration:这是一个配置Spring的配置类。
(3)@Controller:标明这是一个SpringMVC的Controller控制器。
(4)@ResponseBody: 如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解
(5)main方法:在main方法中启动一个应用,即:这个应用的入口。
当然,我们也可以用restfull风格的注解(@restcontroller)来标注,如下代码:
package com.wx.controlers;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
@RestController
@SpringBootApplication
//@Configuration //因为@SpringBootApplication包含了Configuration,所以这里可以省略
public class HelloApp {
@RequestMapping("hello")
//@ResponseBody
public String hello(){
return "Hello";
}
public static void main(String[] args) {
SpringApplication.run(HelloApp.class, args);
}
}
官方文档:
@RestController is a stereotype annotation that combines @ResponseBody and @Controller.
意思是:
@RestController注解相当于@ResponseBody + @Controller合在一起的作用。
如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,配置的视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。
5. 启动应用
在Spring Boot项目中,启动的方式有两种,一种是直接run Java Application另外一种是通过Spring Boot的Maven插件运行。
第一种:
第二种:
在项目上单击右键===》Run as===> Maven build…
看到如下信息,说明启动成功了
[ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http)
[ main] com.wx.controlers.HelloApp : Started HelloApp in 3.126 seconds (JVM running for 42.425)
启动浏览器运行
6 spring boot的核心
(1) 入口类和@SpringBootApplication
Spring Boot的项目一般都会有*Application的入口类,入口类中会有main方法,
这是一个标准的Java应用程序的入口方法。
@SpringBootApplication注解是Spring Boot的核心注解,它其实是一个组合注解:
该注解主要组合了以下注解:
1.@SpringBootConfiguration:这是Spring Boot项目的配置注解,这也是一个组合注解:
在Spring Boot项目中推荐使用@ SpringBootConfiguration替代@Configuration,所以HelloApp入口类上的Configuration注解可以注释掉
2.@EnableAutoConfiguration:启用自动配置,该注解会使Spring Boot根据项目中依赖的jar包自动配置项目的配置项:
a)如:我们添加了spring-boot-starter-web的依赖,项目中也就会引入SpringMVC的依赖,Spring Boot就会自动配置tomcat和SpringMVC
3.@ComponentScan:默认扫描@SpringBootApplication所在类的同级目录以及它的子目录。
如果我们在启动类上又配置了@ComponentScan, 那么该默认的扫描失效,当前包也要重新纳入扫描!
(2) 关闭自动配置
通过上述,我们得知,Spring Boot会根据项目中的jar包依赖,自动做出配置,Spring Boot支持的自动配置如下(非常多):
如果我们不需要Spring Boot自动配置,想关闭某一项的自动配置,该如何设置呢?
比如:我们不想自动配置Redis,想手动配置。
当然了,其他的配置就类似了。
7 解决jsp页面的支持问题
由于Spring boot使用的内嵌的tomcat,而内嵌的tamcat是不支持jsp页面的,所有需要导入额外的包才能解决。
org.apache.tomcat.embed tomcat-embed-jasper provided 修改启动类
package com.wx.controlers;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
@Controller
@SpringBootApplication
//@Configuration //因为@SpringBootApplication包含了Configuration,所以这里可以省略
public class HelloApp {
@RequestMapping("hello")
//@ResponseBody
public String hello(){
return "Hello";
}
public static void main(String[] args) {
SpringApplication.run(HelloApp.class, args);
}
}
写一个Hello.jsp的页面放到webapp目录下:
编写全局配置文件application.properties,如图所示
关于全局配置文件,以后再讲解!
重新运行,结果如图