springboot介紹
官網:spring.io
Spring Boot is designed to get you up and running as quickly as possible, with minimal upfront configuration of Spring. Spring Boot takes an opinionated view of building production-ready applications.
spring boot 致力於簡潔,讓開發者寫更少的配置,程序能夠更快的運行和啟動。它是下一代javaweb框架,並且它是spring cloud(微服務架構)的基礎。
springboot主要是是針對單服務器,后續還有spring cloud針對多服務器協調的應用 。
springboot與spring cloud的簡單區別
- springboot是針對單服務器,spring cloud是多服務器之間協調用
建立第一個程序
主要步驟如下
- 創建項目
- pom.xml解釋-可以略過
- 配置application.yml
- 創建boot啟動類
項目的目錄結構如下:
創建項目
1.新建項目 選 擇spring initializer項目
輸入project Metadata
選擇依賴 web=>sprbing web starter,其它也可以。
確認項目路徑
POM.xml解釋
parent里配置spring boot的依賴。
spring-boot-starter-parent:自動導入web模塊運行時所依賴的組件
pom是啟動器,根據不同的場會自動配置使用到的相關技術 。簡化開發。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
//parent 是springboot必須的。
//jdk的版本
<properties>
<java.version>1.8</java.version>
</properties>
//項目的插件
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
//項目的依賴
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
配置application.yml
在src-main-resources下右擊添加文件
添加 application.yml文件,配置文件名是固定的
配置服務器端口9001
server:
port: 9001
同時刪除項目中自帶的一些不必要的文件 ,
yml文件
yml文件是以數據為中心,比json,xml等文件更適合做配置文件
用縮近表示層級,不能使用tab,只能使用空格 。大小寫敏感
YAML支持三種數據格式:對象,數組,基本數據類型
舉例:
person:name: 張三 age: 20 sex: false birthday: 2019/01/11 list: - a - b map: -k1: v1 -k2: v2 -dog: {name: ww,age: 12} dog: name: ww age: 2
創建boot啟動類
在main-java-下建新類, web.controller.HelloController
- RestController 添加在類的上面,表示以下的類都可以使用
- RestController表示兩個注解的結合,分別是@Controller 和@ResponseController注解,
所以下面的方法中不需要再添加 @Responsecontroller注解了
- 方法的注解前面要加上相應的注解mapping.
package com.example.demo.web.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController //@Controller +@responsecontroller
public class HelloController {
@RequestMapping("/hello")
public String Hello(String name){
return name+" say good evening";
}
}
- 在DemoApplication中的main方法中右擊啟動
可以在控制台中看到服務器端口會自動讀取application.yml中的配置端口 9001
瀏覽器中輸入網址進行測試 ,返回方法中的結果,測試成功
注解的解釋
參考:https://baijiahao.baidu.com/s?id=1623648034778672046&wfr=spider&for=pc
@SpringBootApplication注解
@SpringBootApplication是一個復合注解,包括@ComponentScan,@SpringBootConfiguration,@EnableAutoConfiguration。
@SpringBootConfiguration繼承自@Configuration,二者功能也一致,標注當前類是配置類,並會將當前類內聲明的一個或多個以@Bean注解標記的方法的實例納入到srping容器中,並且實例名就是方法名
@EnableAutoConfiguration的作用啟動自動的配置。據你添加的jar包來配置你項目的默認配置,比如根據spring-boot-starter-web,來判斷你的項目是否需要添加了webmvc和tomcat,就會自動的幫你配置web項目中所需要的默認配置。
@ComponentScan,掃描當前包及其子包下被@Component,@Controller,@Service,@Repository注解標記的類並納入到spring容器中進行管理
@ResponseBody
表示該方法的返回結果直接寫入HTTP response body中,一般在異步獲取數據時使用,用於構建RESTful的api。在使用@RequestMapping后,返回值通常解析為跳轉路徑,加上@esponsebody后返回結果不會被解析為跳轉路徑,而是直接寫入HTTP response body中。比如異步獲取json數據,加上@Responsebody后,會直接返回json數據。該注解一般會配合@RequestMapping一起使用
@Controller
用於定義控制器類,在spring項目中由控制器負責將用戶發來的URL請求轉發到對應的服務接口(service層),一般這個注解在類中,通常方法需要配合注解@RequestMapping
@RestController
用於標注控制層組件(如struts中的action),@ResponseBody和@Controller的合集