Intelij IDEA創(chuàng)建SpringBoot項(xiàng)目

springboot介紹

官網(wǎng):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 致力于簡(jiǎn)潔,讓開發(fā)者寫更少的配置,程序能夠更快的運(yùn)行和啟動(dòng)。它是下一代javaweb框架,并且它是spring cloud(微服務(wù)架構(gòu))的基礎(chǔ)。

springboot主要是是針對(duì)單服務(wù)器,后續(xù)還有spring cloud針對(duì)多服務(wù)器協(xié)調(diào)的應(yīng)用 。

建立第一個(gè)程序

主要步驟如下

  1. 創(chuàng)建項(xiàng)目

  2. pom.xml解釋-可以略過

  3. 配置application.yml

  4. 創(chuàng)建boot啟動(dòng)類

項(xiàng)目的目錄結(jié)構(gòu)如下:

image

創(chuàng)建項(xiàng)目

1.新建項(xiàng)目 選 擇spring initializer項(xiàng)目

image

輸入project Metadata

image

選擇依賴 web=>sprbing web starter,其它也可以。

image

確認(rèn)項(xiàng)目路徑

image

POM.xml解釋

parent里配置spring boot的依賴。

spring-boot-starter-parent:自動(dòng)導(dǎo)入web模塊運(yùn)行時(shí)所依賴的組件

pom是啟動(dòng)器,根據(jù)不同的場(chǎng)會(huì)自動(dòng)配置使用到的相關(guān)技術(shù) 。簡(jiǎn)化開發(fā)。

 <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>

 //項(xiàng)目的插件
 <plugins>
 <plugin>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-maven-plugin</artifactId>
 </plugin>
 </plugins>
 //項(xiàng)目的依賴
 <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文件,配置文件名是固定的

image

配置服務(wù)器端口9001

server:
 port: 9001
?

同時(shí)刪除項(xiàng)目中自帶的一些不必要的文件 ,

yml文件

yml文件是以數(shù)據(jù)為中心,比json,xml等文件更適合做配置文件

用縮近表示層級(jí),不能使用tab,只能使用空格 。大小寫敏感

YAML支持三種數(shù)據(jù)格式:對(duì)象,數(shù)組,基本數(shù)據(jù)類型

舉例:
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
?

創(chuàng)建boot啟動(dòng)類

在main-java-下建新類, web.controller.HelloController

  • RestController 添加在類的上面,表示以下的類都可以使用

  • RestController表示兩個(gè)注解的結(jié)合,分別是@Controller 和@ResponseController注解,

    所以下面的方法中不需要再添加 @Responsecontroller注解了

  • 方法的注解前面要加上相應(yīng)的注解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方法中右擊啟動(dòng)
image

可以在控制臺(tái)中看到服務(wù)器端口會(huì)自動(dòng)讀取application.yml中的配置端口 9001

image

瀏覽器中輸入網(wǎng)址進(jìn)行測(cè)試 ,返回方法中的結(jié)果,測(cè)試成功

image

注解的解釋

參考:https://baijiahao.baidu.com/s?id=1623648034778672046&wfr=spider&for=pc

@SpringBootApplication注解

@SpringBootApplication是一個(gè)復(fù)合注解,包括@ComponentScan,@SpringBootConfiguration,@EnableAutoConfiguration。

@SpringBootConfiguration繼承自@Configuration,二者功能也一致,標(biāo)注當(dāng)前類是配置類,并會(huì)將當(dāng)前類內(nèi)聲明的一個(gè)或多個(gè)以@Bean注解標(biāo)記的方法的實(shí)例納入到srping容器中,并且實(shí)例名就是方法名

@EnableAutoConfiguration的作用啟動(dòng)自動(dòng)的配置。據(jù)你添加的jar包來配置你項(xiàng)目的默認(rèn)配置,比如根據(jù)spring-boot-starter-web,來判斷你的項(xiàng)目是否需要添加了webmvc和tomcat,就會(huì)自動(dòng)的幫你配置web項(xiàng)目中所需要的默認(rèn)配置。

@ComponentScan,掃描當(dāng)前包及其子包下被@Component,@Controller,@Service,@Repository注解標(biāo)記的類并納入到spring容器中進(jìn)行管理

@ResponseBody

表示該方法的返回結(jié)果直接寫入HTTP response body中,一般在異步獲取數(shù)據(jù)時(shí)使用,用于構(gòu)建RESTful的api。在使用@RequestMapping后,返回值通常解析為跳轉(zhuǎn)路徑,加上@esponsebody后返回結(jié)果不會(huì)被解析為跳轉(zhuǎn)路徑,而是直接寫入HTTP response body中。比如異步獲取json數(shù)據(jù),加上@Responsebody后,會(huì)直接返回json數(shù)據(jù)。該注解一般會(huì)配合@RequestMapping一起使用

@Controller

用于定義控制器類,在spring項(xiàng)目中由控制器負(fù)責(zé)將用戶發(fā)來的URL請(qǐng)求轉(zhuǎn)發(fā)到對(duì)應(yīng)的服務(wù)接口(service層),一般這個(gè)注解在類中,通常方法需要配合注解@RequestMapping

@RestController

用于標(biāo)注控制層組件(如struts中的action),@ResponseBody和@Controller的合集

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容