一、SpringBoot入门

1、基本介绍

简化Spring应用开发的一个框架、整个Spring技术栈的一个大整合;

J2EE开发的一站式解决方案;

优点:

快速创建独立运行的Spring项目以及与主流框架集成;

使用嵌入式的Servlet容器,应用无需打成WAR包;

starters自动依赖与版本控制;

大量的自动配置,简化开发,也可修改默认值;

无需配置XML,无代码生成,开箱即用;

准生产环境的运行时应用监控;

与云计算的天然集成;

 

2、微服务

martin fowler论文提出。

微服务:架构风格(服务微化)

一个应用应该是一组小型服务;可以通过HTTP的方式进行互通;

单体应用:ALL IN ONE

微服务:每一个功能元素最终都是一个可独立替换和独立升级的软件单元;

 

3、MAVEN设置

maven 的settings.xml配置文件的profiles标签添加下面的代码:

<profile>  <id>jdk-1.8</id>  <activation>    <activeByDefault>true</activeByDefault>    <jdk>1.8</jdk>  </activation>  <properties>    <maven.compiler.source>1.8</maven.compiler.source>    <maven.compiler.target>1.8</maven.compiler.target>    <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>  </properties></profile>

表示maven使用jdk1.8

 

4、Spring Boot HelloWorld

实现功能:

浏览器发送hello请求,服务器接受请求并处理,响应Hello Springboot! 字符串;即浏览器输入 localhost:8080/hello可以看到浏览器显示Hello SpringBoot!字符串;

① 创建一个maven工程(jar);

② 导入spring boot相关的依赖;

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring‐boot‐starter‐parent</artifactId>    <version>1.5.9.RELEASE</version></parent><dependencies>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring‐boot‐starter‐web</artifactId>    </dependency></dependencies>

③ 编写一个主程序,启动Spring Boot应用

/** *  @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用 */@SpringBootApplicationpublic class HelloWorldMainApplication {    public static void main(String[] args) {        // Spring应用启动起来        SpringApplication.run(HelloWorldMainApplication.class, args);    }}

④ 编写相关的Controller

@Controllerpublic class HelloController {    @ResponseBody    @RequestMapping("/hello")    public String hello(){        return "Hello SpringBoot!";    }}

⑤ 运行主程序测试

⑥简化部署

将这个应用打成jar包,直接使用java-jar的命令进行执行;

<!-- 这个插件,可以将应用打包成一个可执行的jar包;-->  <build>       <plugins>           <plugin>               <groupId>org.springframework.boot</groupId>               <artifactId>spring-boot-maven-plugin</artifactId>           </plugin>        </plugins>  </build>

结果:

 

5、Hello World探究

(1)、Pom.xml文件

父项目

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>1.5.9.RELEASE</version></parent>

他的父项目:

<parent><groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>1.5.9.RELEASE</version> <relativePath>../../spring-boot-dependencies</relativePath></parent>

他来真正管理Spring Boot应用里面的所有依赖版本;

也就是Spring Boot的版本仲裁中心;

以后我们导入依赖默认是不需要写版本;(没有在dependencies里面管理的依赖自然需要声明版本号)

启动器:

<dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-web</artifactId></dependency>

spring-boot-starter-web:

spring-boot-starterspring-boot场景启动器;帮我们导入了web模块正常运行所依赖的组件;

Spring Boot将所有的功能场景都抽取出来,做成一个个的starters(启动器),只需要在项目里面引入这些starter相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器。

(2)、主程序类,主入口类

@SpringBootApplicationpublic class HelloWorldMainApplication {    public static void main(String[] args) {        // Spring应用启动起来        SpringApplication.run(HelloWorldMainApplication.class,args);    }}

① @SpringBootApplicationSpring Boot应用标注在某个类上说明这个类是SpringBoot的主配置类,SpringBoot就应该运行这个类的main方法来启动SpringBoot应用;这是一个组合注解。

@Target({ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Documented@Inherited@SpringBootConfiguration@EnableAutoConfiguration@ComponentScan(    excludeFilters = {@Filter(    type = FilterType.CUSTOM,    classes = {TypeExcludeFilter.class}), @Filter(    type = FilterType.CUSTOM,    classes = {AutoConfigurationExcludeFilter.class})})public @interface SpringBootApplication {...}

下面看里面的每个注解含义:

@SpringBootConfigurationSpring Boot的配置类,标注在某个类上,表示这是一个Spring Boot的配置类,里面包含这个@Configuration(也就是Spring里面的配置类);

@Target({ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Documented@Configurationpublic @interface SpringBootConfiguration {}

配置类 —–> 配置文件;配置类也是容器中的一个组件:@Component

@Target({ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Documented@Component //组件注解 public @interface Configuration {    @AliasFor(        annotation = Component.class    )    String value() default "";}

② @EnableAutoConfiguration:开启自动配置功能;

以前我们需要配置的东西,Spring Boot帮我们自动配置;@EnableAutoConfiguration告诉SpringBoot开启自动配置功能,这样自动配置才能生效;

@AutoConfigurationPackage@Import({AutoConfigurationImportSelector.class})public @interface EnableAutoConfiguration {}

@AutoConfigurationPackage:自动配置包

@Import(AutoConfigurationPackages.Registrar.class)Spring的底层注解@Import,给容器中导入一个组件;导入的组件由AutoConfigurationPackages.Registrar.class指定。 也就是: 将主配置类(@SpringBootApplication标注的类)的所在包及下面所有子包里面的所有组件扫描到Spring容器;,所以如果上面的controller 如果不是在主配置类所在的包(或者子包)下,就不能扫描到。

@Import(EnableAutoConfigurationImportSelector.class): 给容器中导入组件(不在同一个包下面的)EnableAutoConfigurationImportSelector:导入哪些组件的选择器;将所有需要导入的组件以全类名的方式返回,这些组件就会被添加到容器中;会给容器中导入非常多的自动配置类(xxxAutoConfiguration);就是给容器中导入这个场景需要的所有组件,并配置好这些组件; 

有了自动配置类,免去了我们手动编写配置注入功能组件等的工作; 里面的getCandidateConfigurations调用了下面的一个方法: SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader) Spring Boot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;以前我们需要自己配置的东西,自动配置类都帮我们;

J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-xxx.RELEASE.jar; 

6、使用Spring Initializer快速创建Spring Boot项目

IDE都支持使用Spring的项目创建向导快速创建一个Spring Boot项目。选择我们需要的模块,向导会联网创建Spring Boot项目,默认生成的Spring Boot项目; 主程序生成好了,我们只需要我们自己的逻辑。

resources : 文件夹中目录结构

static:保存所有的静态资源; js css images

templates:保存所有的模板页面;(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页 面);可以使用模板引擎(freemarkerthymeleaf);

application.properties:Spring Boot应用的配置文件,可以修改一些默认设置;

结构目录:

简单Controller,注意@RestController注解。

package com.zxin.springboot.controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;import org.springframework.web.bind.annotation.RestController;//@ResponseBody // 这个类的所有方法返回的数据直接写给浏览器(如果是对象 -> 转成json)//@Controller@RestController // 这个注解的作用和上面两个一起的作用相同 (就是 ResponseBody和Controller的合体)public class HelloController {    @ResponseBody //如果每个类都需要写,麻烦    @RequestMapping("/hello")    public String hello(){        return "hello quick SpringBoot!";    }}