Spring Boot学习笔记一

Spring Boot简介

前言:本章简单介绍Spring boot的使用。

  (第二天springboot的学习之路:https://www.cnblogs.com/LBJLAKERS/p/12003109.html)  

  • 简化Spring应用开发的一个框架
  • 整个Spring技术栈的一个大整合
  • J2EE开发的一站式解决方案

Sping Boot 所具备的特征有:

  • 可以创建独立的Spring应用程序,并基于其Maven或Gradle插件,可以创建可这性的JARS和WARS
  • 内嵌Tomact或Jetty等Servlet容器
  • 提供自动配置的starter项目对象模型(POMS)以简化Maven配置
  • 尽可能自动配置Spring容器
  • 提供准备好的特性,如指标、健康检查和外部化配置
  • 绝对没有代码生成,不需要XML配置

开发环境配置

  • –jdk1.8:Spring Boot 推荐jdk1.7及以上;java version "1.8.0_112"
  • –maven3.x:maven 3.3以上版本;Apache Maven 3.3.9
  • –IntelliJIDEA2017:IntelliJ IDEA 2017.3.3 x64、STS
  • –SpringBoot 2.0.2.RELEASE:统一环境;
  • Maven环境在maven文件的setting.xml 文件中配置一段
    <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工程项目,如下图

    

    或者直接在网站上直接生成项目,然后导入到开发工具中(https://start.spring.io

  •   导入相应的Spring Boot坐标
     1   <parent>
     2     <groupId>org.springframework.boot</groupId>
     3     <artifactId>spring-boot-starter-parent</artifactId>
     4     <version>2.2.2.RELEASE</version>
     5   </parent>
     6 
     7   <dependencies>
     8     <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
     9     <dependency>
    10       <groupId>org.springframework.boot</groupId>
    11       <artifactId>spring-boot-starter-web</artifactId>
    12       <version>2.2.1.RELEASE</version>
    13     </dependency>
    14   </dependencies>

     

  • 编写一个主程序,启动Spring Boot应用
     1 /**
     2 * @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用
     3 */
     4 @SpringBootApplication
     5 public class HelloWorldMainApplication {
     6     public static void main(String[] args) {
     7     // Spring应用启动起来
     8     SpringApplication.run(HelloWorldMainApplication.class,args);
     9     }
    10 }
  • 创建一个Controller类
    1 @Controller
    2 public class HelloController {
    3    @ResponseBody
    4    @RequestMapping("/hello")
    5    public String hello(){
    6       return "Hello World!";
    7    }
    8 }
  • 启动Spring Boot应用。我们可以从控制台可以看出:Tomcat被初始化端口8080、用8080端口启动。

    

 

 

  •  解析注解:
    • @SpringBootApplication:SpringBoot应用标注在某个类上说明这个类是SpringBoot的主配置类,SpringBoot就应该运行这个类的main方法来启动SpringBoot的应用。
    • @SpringBootConfiguration:SpringBoot配置类。标注在某个类上,表示这个是Spring Boot的配置类
    • @Configuration:配置类上来标注这个注解。配置类-----配置文件;配置类也是容器中的一个组件,@Component
    • @EnableAutoConfiguration:开启自动配置功能。底层部分代码:
      1 @AutoConfigurationPackage
      2 @Import(EnableAutoConfigurationImportSelector.class)
      3 public @interface EnableAutoConfiguration {

       继续进入

      @AutoConfigurationPackage的注解底层代码
      1 @Target({ElementType.TYPE})
      2 @Retention(RetentionPolicy.RUNTIME)
      3 @Documented
      4 @Inherited
      5 @Import({Registrar.class})
      6 public @interface AutoConfigurationPackage {
      7 }

      在进入到Registar的底层

       1 static class Registrar implements ImportBeanDefinitionRegistrar, DeterminableImports {
       2         Registrar() {
       3         }
       4 
       5         public void registerBeanDefinitions(AnnotationMetadata metadata, BeanDefinitionRegistry registry) {
       6             AutoConfigurationPackages.register(registry, (new AutoConfigurationPackages.PackageImport(metadata)).getPackageName());
       7         }
       8 
       9         public Set<Object> determineImports(AnnotationMetadata metadata) {
      10             return Collections.singleton(new AutoConfigurationPackages.PackageImport(metadata));
      11         }
      12     }

       

    • @AutoConfigurationPackage:自动配置包

      @Import(AutoConfigurationPackage.Registar.class):Spring的底层注解@Import,给容器中导入一个组件;导入的组件由
      AutoConfigurationPackages.Registrar.class;
      将主配置类(@SpringBootApplication标注的类)的所在包及下面所有子包里面的所有组件扫描到Spring容器;

    • @Import(EnableAutoConfigurationImportSelector.class);给容器导入组件。EnableAutoConfigurationImportSelector:导入哪些组件的选择器;

      将所有需要导入的组件以全类名的方式返回;这些组件就会被添加到容器中;
      会给容器中导入非常多的自动配置类(xxxAutoConfiguration);就是给容器中导入这个场景需要的所有组件,
      并配置好这些组件;

    

       有了自动配置类,免去了我们手动编写配置注入功能组件等的工作;

      有了自动配置类,免去了我们手动编写配置注入功能组件等的工作;
      SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader);
      Spring Boot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将
      这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;以前我们需要自己配置的东西,自动配置类都帮我们;
      J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-1.5.9.RELEASE.jar;

Spring Boot的热部署

  • 使用Spring Initializer快速创建Spring Boot项目.
  • Spring Boot的热部署需要导入一个坐标,代码完成更改之后,只需要重启即可,重启的快捷键(Ctrl+F9)
    1 <dependency> 
    2 <groupId>org.springframework.boot</groupId> 
    3 <artifactId>spring-boot-devtools</artifactId> 
    4 <optional>true</optional> 
    5 </dependency>

Spring Boot的配置文件

  • application.properties
  • application.yml

  例如:yaml中的配置文件的方式:

server:
    port: 8081

  yaml语法

  • k:(空格)v:表示一对键值对(空格必须有);
  • 以空格的缩进来控制层级关系;只要是左对齐的一列数据,都是同一个层级的(如上面的代码所示)
  • 属性和值也是大小写敏感;

  • 创建一个Person的类
      1 package zh.stu.springboot.Model;
      2 
      3 import org.springframework.boot.context.properties.ConfigurationProperties;
      4 import org.springframework.stereotype.Component;
      5 
      6 import java.util.Date;
      7 import java.util.List;
      8 import java.util.Map;
      9 
     10 /**
     11  * @ConfigurationProperties("person")   使用来读取application.yaml文件中的配置,其中里面的参数表示,读取的是以person开头的配置
     12  * 
     13  * 只有这个组件是容器的组件,才能容器提供的@ConfigurationProperties功能
     14  */
     15 @Component
     16 @ConfigurationProperties(prefix="person")
     17 public class Person {
     18     String lastName;
     19 
     20     int age;
     21 
     22     boolean boss;
     23 
     24     Date birth;
     25 
     26     Map<String,String> maps;
     27 
     28     List<String> list;
     29 
     30     dog dog;
     31 
     32     @Override
     33     public String toString() {
     34         return "Person{" +
     35                 "lastName='" + lastName + '\'' +
     36                 ", age=" + age +
     37                 ", boss=" + boss +
     38                 ", birth=" + birth +
     39                 ", maps=" + maps +
     40                 ", list=" + list +
     41                 ", dog=" + dog +
     42                 '}';
     43     }
     44 
     45     public zh.stu.springboot.Model.dog getDog() {
     46         return dog;
     47     }
     48 
     49     public void setDog(zh.stu.springboot.Model.dog dog) {
     50         this.dog = dog;
     51     }
     52 
     53     public String getLastName() {
     54         return lastName;
     55     }
     56 
     57     public void setLastName(String lastName) {
     58         this.lastName = lastName;
     59     }
     60 
     61     public int getAge() {
     62         return age;
     63     }
     64 
     65     public void setAge(int age) {
     66         this.age = age;
     67     }
     68 
     69     public boolean isBoss() {
     70         return boss;
     71     }
     72 
     73     public void setBoss(boolean boss) {
     74         this.boss = boss;
     75     }
     76 
     77     public Date getBirth() {
     78         return birth;
     79     }
     80 
     81     public void setBirth(Date birth) {
     82         this.birth = birth;
     83     }
     84 
     85     public Map<String, String> getMaps() {
     86         return maps;
     87     }
     88 
     89     public void setMaps(Map<String, String> maps) {
     90         this.maps = maps;
     91     }
     92 
     93     public List<String> getList() {
     94         return list;
     95     }
     96 
     97     public void setList(List<String> list) {
     98         this.list = list;
     99     }
    100 
    101 }
  • 在创建一个dog的类
     1 package zh.stu.springboot.Model;
     2 
     3 public class dog {
     4 
     5     private String name;
     6 
     7     @Override
     8     public String toString() {
     9         return "dog{" +
    10                 "name='" + name + '\'' +
    11                 '}';
    12     }
    13 
    14     public String getName() {
    15         return name;
    16     }
    17 
    18     public void setName(String name) {
    19         this.name = name;
    20     }
    21 }
  • 在pom.xml文件中添加一个依赖,这样在配置application.yaml 语法的时候就可以有提示
    1 <!‐‐导入配置文件处理器,配置文件进行绑定就会有提示‐‐>
    2 <dependency>
    3      <groupId>org.springframework.boot</groupId>
    4      <artifactId>spring‐boot‐configuration‐processor</artifactId>
    5      <optional>true</optional>
    6 </dependency>
  • 配置yaml文件,向属性值中加入数据
    1 person:
    2   lastName: zhangH
    3   age: 23
    4   boss: false
    5   birth: 2020/2/2
    6   maps: {1:1,2:2}
    7   list: [cat,dog]
    8   dog:
    9     name: dudu
  • 测试数据输出:
     1 package zh.stu.springboot;
     2 
     3 import org.junit.jupiter.api.Test;
     4 import org.springframework.beans.factory.annotation.Autowired;
     5 import org.springframework.boot.test.context.SpringBootTest;
     6 import org.springframework.context.ApplicationContext;
     7 import zh.stu.springboot.Model.Person;
     8 
     9 import java.beans.PersistenceDelegate;
    10 
    11 @SpringBootTest
    12 public class yamltest {
    13 
    14     @Autowired
    15     Person person;
    16 
    17     @Autowired
    18     ApplicationContext context;
    19     @Test
    20     public void contextload(){
    21         System.out.println(person);
    22     }
    23 }
  • 在控制台输出结果
    Person{lastName='zhangH', age=23, boss=false, birth=Sun Feb 02 00:00:00 CST 2020, maps={61=, 122=}, list=[cat, dog], dog=dog{name='dudu'}}

 @PropertySource    @ImportResource    @Bean

  • @PropertySource:将配置文件中配置的每一个属性的值,映射到这个组件中。@ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定;

   prefix = "person":配置文件中哪个下面的所有属性进行一一映射。只有这个组件是容器中的组件,才能容器提供的@ConfigurationProperties功能;
   @ConfigurationProperties(prefix = "person")默认从全局配置文件中获取值;
   @PropertySource(value = {"classpath:person.properties"})

  • @ImportResource:导入spring的配置文件,让配置文件里面的内容生效。因为spring boot里面没有spring的配置文件,如果自己编写spring的配置文件,想让其生效那么就需要使用

   @ImportResource这个注解例如:

@ImportResource(locations = {"classpath:beans.xml"})
  • 配置类@Configuration------>Spring配置文件     

    使用@Bean给容器中添加组件

     1 /**
     2 * @Configuration:指明当前类是一个配置类;就是来替代之前的Spring配置文件
     3 *
     4 * 在配置文件中用<bean><bean/>标签添加组件
     5 * *
     6 /
     7 @Configuration
     8 public class MyAppConfig {
     9      //将方法的返回值添加到容器中;容器中这个组件默认的id就是方法名
    10      @Bean
    11      public HelloService helloService02(){
    12          System.out.println("配置类@Bean给容器中添加组件了...");
    13          return new HelloService();
    14      }
    15 }
  • Spring Boot配置加载、顺序?
  1. properties文件
  2. YAML文件
  3. 系统环境变量
  4. 命令行参数



 

posted @ 2019-12-07 19:22  白天黑天阴天  阅读(201)  评论(0编辑  收藏  举报