SpringBoot2
1、入门程序
两大特性:依赖管理、自动配置
-
创建一个maven项目
-
pom.xml文件
<?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>org.miao</groupId>
<artifactId>SpringBoot</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
- 创建
package com.miao;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* 主程序类
* @SpringBootApplication :这是一个SpringBoot应用
*
*/
@SpringBootApplication
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class,args);
}
}
- 在主类的包里面创建controller·包
package com.miao.controller;
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;
import javax.annotation.Resource;
/**
* @ResponseBody :这个类的所有方法数据直接返回给浏览器而不是跳转页面
* @RestController:相当于 @ResponseBody 和 @Controller 合体
*/
//@ResponseBody
//@Controller
@RestController
public class HellowController {
@RequestMapping("/hello")
public String handle01(){
return "hello,spring boot 2";
}
}
- 运行主方法
- 访问localhost:8080/hello
2、底层注解
2.1、@Configuration
@Configuration//告诉Spring这是一个配置类 == 配置文件
import com.miao.bean.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration//告诉Spring这是一个配置类 == 配置文件
public class MyConfig {
@Bean//给容器中添加组件。以方法名为组件id ,返回类型为组价类型,返回的值就是在容器中的实例
public User user01() {
return new User("miao",12);
}
@Bean("tom")//自定义组件名(不是tomcatPet而是tom)
public Pet tomcatPet(){
return new Pet();
}
}
@Configuration(proxyBeanMethods=false) 为false创建实例
时不会查看容器中是否已经有此组件,直接创建一个新组建(更省)
2.2、@Import()
@Import({User.class, Handle.class}) 导入组件
2.3、@Conditional()
条件装配,满足Conditional指定的条件时,则进行组件注入
ctrl+H 打开 hierarchy (n. 等级制度(尤指社会或组织); 统治集团; 层次体系;
)
ctrl + alt + v 自动补全返回值类型和变量名
@ConditionalOnBean(name="tom")//容器中有tom时。装配user01
@Bean//给容器中添加组件。以方法名为组件id ,返回类型为组价类型,返回的值就是在容器中的实例
public User user01() {
return new User("miao",12);
}
@ConditionalOnBean(name="tom")//容器中有tom时,装配user01
2.4、@ConfigurationProperties
@ConfigurationProperties配置绑定
mycar.brand="yadi"
mycar.price=123
@Component //只有在容器中的组件才能享有spring的功能
@ConfigurationProperties(prefix="mycar")
public class Car {
private String brand;
private Integer price;
@EnableConfigurationProperties(Car.class)有两个功能(在使用第三方类时可以使用这个)
1.开启Car的配置绑定功能
2.把Car这个组件自动注入到容器中
3、最佳实践
- 引入场景依赖 链接
- 查看自动配置了那些
配置文件debug=true
可以看到配置报告 - 查看是否需要修改
3.1、LomBok
1、导入lombok依赖(自动生成getter、setter方法(在编译的时候所以在源码中还是看不到))
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
2、下载插件
3、@Data @ToString 等等等等
3.2、dev-tool
热更新,每次启动项目之后,再改变代码只要按ctrl+F9就可以(编译 build project)
1、导入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
4、核心功能
4.1、配置文件
yaml:YAML是"YAML Ain’t a Markup Language"(YAML不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:“Yet Another Markup Language”(仍是一种标记语言),但为了强调这种语言以数据做为中心,而不是以标记语言为重点,而用反向缩略语重命名。
非常适合做以数据为中心的配置文件
语法:
- Key:value kv直接有空格
- 大小写敏感
- 使用缩进表示层级关系
- 缩进不允许使用table,只允许空格
- ‘#’表示注释
- 字符串无需加引号,如果要加,‘’与“”表示字符串内容会被转义/不转义
- 字面量:单个的不可再分的值。data,boolean,string,number,null
k: v(注意:k v之间有一个空格) - 对象:键值对的集合。map,hash,set,object
行内写法 k:{k1:v1,k2:v2}
#或
k:
k1:v1
k2:v2
- 数组:arrary,list,queue
行内写法: k:[v1,v2,v3]
#或
k:
- v1
- v2
- v3
因为内容太多了,我下面的部分都分开写了