一.Spring Boot简介
-
Spring 诞生时是 Java 企业版(Java Enterprise Edition,JEE,也称 J2EE)的轻量级代替品.无需开发重量级的 Enterprise JavaBean(EJB),Spring 为企业级 Java 开发提供了一种相对简单的方法,通过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java Object,POJO)实现了 EJB 的功能
-
虽然 Spring 的组件代码是轻量级的,但它的配置却是重量级的
-
第一阶段:xml配置
在Spring 1.x时代,使用Spring开发满眼都是xml配置的Bean,随着项目的扩大,我们需要把xml配置文件放到不同的配置文件里,那时需要频繁的在开发的类和配置文件之间进行切换
- 第二阶段:注解配置
在Spring 2.x 时代,随着JDK1.5带来的注解支持,Spring提供了声明Bean的注解(例如@Component、@Service),大大减少了配置量.主要使用的方式是应用的基本配置(如数据库配置)用xml,业务配置用注解
- 第三阶段:java配置
Spring 3.0 引入了基于 Java 的配置能力,这是一种类型安全的可重构配置方式,可以代替 XML.我们目前刚好处于这个时代,Spring4.x和Spring Boot都推荐使用Java配置
所有这些配置都代表了开发时的损耗.因为在思考 Spring 特性配置和解决业务问题之间需要进行思维切换,所以写配置挤占了写应用程序逻辑的时间.除此之外,项目的依赖管理也是件吃力不讨好的事情.决定项目里要用哪些库就已经够让人头痛的了,你还要知道这些库的哪个版本和其他库不会有冲突,这难题实在太棘手.并且,依赖管理也是一种损耗,添加依赖不是写应用程序代码.一旦选错了依赖的版本,随之而来的不兼容问题毫无疑问会是生产力杀手
- Spring Boot 主要目标是
- 为所有 Spring 的开发提供一个从根本上更快的入门体验
- 开箱即用,但通过自己设置参数,即可快速摆脱这种方式
- 提供了一些大型项目中常见的非功能性特性,如内嵌服务器、安全、指标,健康检测、外部化配置等
- 绝对没有代码生成,也无需 XML 配置。
二.Spring Boot入门
- 无论是Spring:IOC OOP还是SpringMVC都需要去
http://spring.io/
下载对应的开发包
-
我们以前所学的Spring之类的都是在Spring framework下的
-
推荐使用这两个版本,不建议使用最新版,点击Reference Doc 可以查看对应的文档
- 往下拉我们会发现要使用Spring Boot要引入的依赖
<?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>com.example</groupId>
<artifactId>myproject</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
</parent>
<!-- Add typical dependencies for a web application -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<!-- Package as an executable jar -->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
1.引导类的创建
(1).创建一个maven工程
(2).在pom.xml引入对应的依赖
<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
</parent>
<!-- Add typical dependencies for a web application -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<!-- Package as an executable jar -->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
- 这些包我们都很熟悉
(3).创建引导类
- 当然此时仅仅只是一个普通的类,运行时Spring Boot并不会运行
- 启动Spring Boot要靠注解
public class Application {
public static void main(String[] args) {
System.out.println("Spring boot启动");
}
}
@SpringBootApplication
public class Application {
public static void main(String[] args) {
System.out.println("Spring boot启动");
SpringApplication.run(Application.class, args);
}
}
- 图案后输出是内置tomcat在启动
-
我们可以访问
http://localhost:8080/
尝试下
-
我们再来分析下注解
@SpringBootApplication
,进入对应的源码
-
前四个都是元注解(能出现的位置;改变注解生命周期;是否把文档给输出出来;被注解的类是否继承它父类上的注解)
-
@SpringBootConfiguration
:打开它的源码
@Configuration
基于注解IOC配置里面的Configuration,作用:表明当前类是个配置类,相当于spring的一个配置类
@EnableAutoConfiguration
启用自动配置
ComponentScan
扫描包,能扫描的类:当前被注解类的包及其子包
2.入门程序(实现基于springboot的springmvc配置)
- 原来控制器配法是
@Controller
- 现在是这个,并且响应JSON类型
@RestController
@RequestMapping("/springmvc")
public class HelloController {
@RequestMapping("/hello")
public String sayHello() {
return "hello spring boot";
}
}
-
访问
http://localhost:8080/springmvc/hello
-
这种配置和原来的写法相比较,很多都省略了,spring boot带来的好处就是越项目越来越精简
-
Spring boot启动每次控制台输出图案,如果不想输出可以控制,不过需要代码来控制
@SpringBootApplication
public class Application {
public static void main(String[] args) {
System.out.println("Spring boot启动");
SpringApplication application = new SpringApplication(Application.class);
application.setBannerMode(Mode.OFF);
application.run(args);//原来一行代码变三行,有点得不偿失 这样就不会输出图案了
}
}