一:SpringBoot是什么?
-
Spring Boot它本身并不提供Spring框架的核心特性以及扩展功能,只是用于快速、敏捷地开发新一代基于Spring框架的应用程序。也就是说,它并不是用来替代Spring的解决方案,而是和Spring框架紧密结合用于提升Spring开发者体验的工具。
同时它集成了大量常用的第三方库配置(例如Jackson, JDBC, Mongo, Redis, Mail等等),Spring Boot应用中这些第三方库几乎可以零配置的开箱即用(out-of-the-box),大部分的Spring Boot应用都只需要非常少量的配置代码,开发者能够更加专注于业务逻辑
注1:敏捷式开发
注2:spring boot其实不是什么新的框架,它默认配置了很多框架的使用方式,
就像maven整合了所有的jar包,spring boot整合了所有的框架spring cloud/dubbo
注3:>=jdk1.8
二.使用Idea配置SpringBoot项目
2.1 创建SpringBoot项目
File–>New–>Project…
Spring Initializr
Maven Project
Web
2.2 目录结构
src/main/java:主程序入口 Application,可以通过直接运行该类来启动Spring Boot应用
src/main/resources:配置目录,该目录用来存放应用的一些配置信息,比如应用名、服务端口、数据库配置等。由于我们应用了Web模块,因此产生了 static目录与templates目录,前者用于存放静态资源,如图片、CSS、JavaScript等;后者用于存放Web页面的模板文件。
src/test:单元测试目录,生成的 ApplicationTests 通过 JUnit4实现,可以直接用运行 Spring Boot应用的测试。
application.properties/application.yml 用于存放程序的各种依赖模块的配置信息,比如 服务端口,数据库连接配置等。。。
注1:包和类不能乱改,只能在com.zking.springboot01建子包,
因为程序只加载Application.java所在包及其子包下的内容
com.zking.springboot01
controller
service
mapper
model
2.3 springboot的配置修改
application.properties–>application.yml
server.port=80
#server.context-path=/s01
server.servlet.context-path=/s01
yml写法 (连接数据库):
server:
port: 8080
servlet:
context-path: /springboot
mysql:
url: jdbc:mysql://localhost:3306/book02?useUnicode=true&characterEncoding=UTF-8
user-name: book
Password: 123
driver: com.jdbc.driver
@RestController=@Controller+@ResponseBody
注1:application.yml,yml是什么格式?
自定义属性
属性封装类
三:获取yml里的值
yml
server:
port: 8080
servlet:
context-path: /springboot
mysql:
url: jdbc:mysql://localhost:3306/book02?useUnicode=true&characterEncoding=UTF-8
user-name: book
Password: 123
driver: com.jdbc.driver
创建mysq值实体类
package com.zk.springbook.entity;
import lombok.ToString;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@ToString
@Component
@ConfigurationProperties(prefix = "mysql")
public class MysqlEntity {
private String driver;
private String url;
private String userName;
public String getDriver() {
return driver;
}
public void setDriver(String driver) {
this.driver = driver;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
}
package com.zk.springbook.controller;
import com.zk.springbook.entity.MysqlEntity;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.annotation.Resource;
@Controller
public class HelloController {
//不创建实体类 直接获取yml值的方法
@Value("${mysql.driver}")
private String driver;
@Value("${mysql.url}")
private String url;
@Value("${mysql.username}")
private String userName;
@Value("${mysql.password}")
private String password;
@ResponseBody
@RequestMapping("/mysql1")
public String mysql1(){
return this.driver+"</br>"+this.url+"</br>"+this.userName+"</br>"+this.password+"</br>";
}
//运用实体类获取yml的值
@Resource
private MysqlEntity mysqlEntity;
@ResponseBody
@RequestMapping("/mysql2")
public MysqlEntity mysql2(){
return this.mysqlEntity;
}
}