spring boot開發(fā)遇到坑之spring-boot-starter-web配置文件使用教程
spring boot簡介
spring boot是最近非常流行的,在spring的框架上改進(jìn)的框架。該框架的目的是為了提高開發(fā)人員的速度,降低配置的難度等等,極大了簡化了開發(fā)流程。具體的詳細(xì)的說明請(qǐng)參考官方文檔。在日常工作中,由于需要搭建一套環(huán)境或者框架的機(jī)會(huì)非常的少,大部分都是在原有的基礎(chǔ)上開發(fā),所以當(dāng)讓你搭建一個(gè)簡單的框架,就會(huì)出現(xiàn)各種各樣的困難,比如說,我在搭建的一個(gè)服務(wù)器的時(shí)候,準(zhǔn)備了一個(gè)小的demo,原以為非常的簡單,結(jié)果遇到了各種各樣的問題,而發(fā)現(xiàn)網(wǎng)上的博客都是零零散散的講一些點(diǎn),很難有一個(gè)完整的流程,包括可能會(huì)遇到的問題。這里對(duì)搭建一個(gè)簡單的項(xiàng)目流程做一個(gè)詳細(xì)的總結(jié),方便日后參考,同時(shí)這一篇博客也是為了下一篇博客tengine反向代理服務(wù)器搭建做一點(diǎn)前置的基礎(chǔ)準(zhǔn)備。
Spring-boot的2大優(yōu)點(diǎn):
1.基于Spring框架的“約定優(yōu)先于配置(COC)”理念以及最佳實(shí)踐之路。
2.針對(duì)日常企業(yè)應(yīng)用研發(fā)各種場景的Spring-boot-starter自動(dòng)配置依賴模塊,且“開箱即用”(約定spring-boot-starter- 作為命名前綴,都位于org.springframenwork.boot包或者命名空間下)。
本篇我將繼續(xù)向小伙伴介紹springboot配置文件的配置,已經(jīng)全局配置參數(shù)如何使用,好了下面開始我們今天的內(nèi)容介紹。
我們知道Spring Boot支持容器的自動(dòng)配置,默認(rèn)是Tomcat,當(dāng)然我們也是可以進(jìn)行修改的:
1、首先我們排除spring-boot-starter-web依賴中的Tomcat:在pom文件中排除tomcat的starter
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency>
2、加入Jetty容器
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency>
這樣我們的springboot容器就修改成Jetty容器了。
為了方便我們的調(diào)試,這里給大家推薦一款http調(diào)試工具:Postman
下面我們聊一下springboot的全局配置文件:application.properties
在開發(fā)中一定遇到過這樣的需求,就是修改我們的容器訪問端口,既然springboot默認(rèn)加載容器,那么端口設(shè)置當(dāng)然是通過配置文件來控制的,相當(dāng)方便我們只需要在配置文件中添加:
server.port=6666
這樣我們的容器端口就修改為6666了。
我們還可以通過配置文件來設(shè)置項(xiàng)目訪問別名:
server.context-path=/springboot
這樣我們啟動(dòng)項(xiàng)目通過http://localhost:6666/springboot1即可訪問到我們的項(xiàng)目
以上只是springboot配置文件配置的冰山一角,比如我們還可以設(shè)置數(shù)據(jù)庫連接配置(database),設(shè)置開發(fā)環(huán)境配置,部署環(huán)境配置,實(shí)現(xiàn)兩者之間的無縫切換。
下面我們一起了解一下關(guān)于springboot的controller的使用,springboot為我們提供了三個(gè)注解:

上一篇我們使用的便是@RestController,下面我們來一起使用@Controller試試:
@Controller
//@ResponseBody
public class RequestTest {
/**
* 不對(duì)請(qǐng)求方式限制
* @return
*/
@RequestMapping(value = "/req")
public String req(){
return "success";
}
}
當(dāng)我們?cè)跒g覽器輸入http://localhost:8080/springboot1/req回車,發(fā)現(xiàn)404
{
"timestamp": 1515332935215,
"status": 404,
"error": "Not Found",
"message": "No message available",
"path": "/springboot1/req"
}
這是為什么呢?這是因?yàn)锧Controller必須配合模板使用,所以我們這里打開maven的pom文件,添加spingboot的模板:
<!-- springboot模板 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency>
然后在我們項(xiàng)目的resources目錄下找到templates(如過沒有,新建一個(gè),但一定要注意文件夾名稱必須保持一致),然后創(chuàng)建一個(gè)success.html這樣我們?cè)俅螁?dòng)項(xiàng)目,訪問剛剛的地址,是不是就Ok了。
不過這里需要說明一點(diǎn),現(xiàn)在的企業(yè)級(jí)開發(fā)都是前后端分離,我們做后臺(tái)服務(wù)只需要返回對(duì)應(yīng)的數(shù)據(jù)即可,當(dāng)然使用模板還有一個(gè)弊端,那就是性能會(huì)造成一定的損耗,所以這里大家簡單了解即可。
上面的介紹中已經(jīng)說了,@Controller+@ResponseBody相當(dāng)于@RestController,所以這里推薦大家使用@RestController。
下面我們來介紹介紹一下@RequestMapping(value = "/req"),這個(gè)注解相信大家已經(jīng)知道他的用法了,當(dāng)然這個(gè)注解不但可以使用在方法上,同樣適用于類。
@RestController
//@Controller
//@ResponseBody
@RequestMapping(value = "/test")
public class RequestTest {
/**
* 不對(duì)請(qǐng)求方式限制
* @return
*/
@RequestMapping(value = "/req")
public String req(){
return "success";
}
/**
* 限制請(qǐng)求方式為GET
* @return
*/
@RequestMapping(value = "/req1", method = RequestMethod.GET)
public String req1(){
return "success";
}
/**
* 限制請(qǐng)求方式為POST
* @return
*/
@RequestMapping(value = "/req2", method = RequestMethod.POST)
public String req2(){
return "success";
}
}
對(duì)于method相信看到這里你一定已經(jīng)知道他的用處了,是的指定訪問類型,沒有設(shè)置默認(rèn)任何方式都可以訪問。不知道小伙伴是否想到如果在類的@RequestMapping設(shè)置過method那么類中的方法默認(rèn)繼承,當(dāng)然也可以在方法處單獨(dú)設(shè)定,優(yōu)先級(jí)的問題,小伙伴自己嘗試一下吧。
下面我將給大家介紹一下如何在Controller中的訪問配置文件中的常量。首先我們?cè)谂渲梦募刑砑樱?/p>
name=hpugs
age=35
content=name:${name};age:${age}
我們?cè)谂渲梦募惺褂贸A?,通過${}來使用。
下面我們?cè)贑ontroller中將參數(shù)注入:
//注入配置文件中的參數(shù)
@Value("${name}")
private String name;
@Value("${age}")
private Integer age;
@Value("${content}")
private String content;
@RequestMapping(value = "/req3", method = RequestMethod.GET)
public String req3(){
return "name=" + name;
}
@RequestMapping(value = "/req4", method = RequestMethod.GET)
public String req4(){
return "age=" + age;
}
@RequestMapping(value = "/req5", method = RequestMethod.GET)
public String req5(){
return "content=" + content;
}
啟動(dòng)我們的項(xiàng)目訪問一下試試。
這樣的使用如果你感覺還不過癮,這里再教大家一招:我們通過類映射配置文件,借助類來進(jìn)行參數(shù)使用,相對(duì)單個(gè)參數(shù)注入要方便一些,首先創(chuàng)建一個(gè)Java類
@Component
@ConfigurationProperties(prefix = "userInfo")
public class UserInfo {
private String names;
private Integer age;
private String content;
public Integer getAge() {
return age;
}
public String getNames() {
return names;
}
public void setNames(String names) {
this.names = names;
}
public void setAge(Integer age) {
this.age = age;
}
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
}
然后在我們的配置文件中設(shè)置參數(shù):
userInfo.names=小破孩
userInfo.age=25
userInfo.content=name:${userInfo.names};age:${userInfo.age}
接線來使我們的Controller:
//注入對(duì)象
@Autowired
private UserInfo userInfo;
@RequestMapping(value = "/req6", method = RequestMethod.GET, produces="text/plain;charset=UTF-8")
public String req6(){
return "name=" + userInfo.getNames();
}
@RequestMapping(value = "/req7", method = RequestMethod.GET)
public String req7(){
return "age=" + userInfo.getAge();
}
@RequestMapping(value = "/req8", method = RequestMethod.GET)
public String req8(){
return "content=" + userInfo.getContent();
}
好了重啟我們的項(xiàng)目訪問試試看。
小伙伴們不知道遇到這個(gè)問題沒?出現(xiàn)了中文亂碼,首先大家先不要著急,我們先看另外一種springboot的配置文件:application.yml。這個(gè)配置文件通過換行空格來替換“;”,我們看一下同樣的配置在yml下面如何配置:
server:
port: 8888
context-path: /springboot1
name: hpugs
age: 35
content: name:${name};age:${age}
userInfo:
names: 小破孩
age: 25
content: name:${userInfo.names};age:${userInfo.age}
現(xiàn)在我們啟動(dòng)項(xiàng)目運(yùn)行試一試。
回到上面的亂碼問題,當(dāng)我們使用yml時(shí)是不是沒有出現(xiàn)亂碼,小伙伴是不是有點(diǎn)郁悶了,這是為什么呢?這是因?yàn)?properties文件使用的是unicode的編碼形式,所以當(dāng)我們輸入中文時(shí)會(huì)出現(xiàn)亂碼。當(dāng)然引亂碼的還有一種原因那就是我能的編碼設(shè)置和前端不一致,這個(gè)我們通過在配置文件中添加:
spring: http: encoding: force: true charset: UTF-8 enabled: true server: tomcat: uri-encoding: UTF-8
來進(jìn)行控制。這里再給大家介紹一下開發(fā)小技巧,springboot為我們提供了在不同開發(fā)環(huán)境下的不同配置文件解決方法:
#yml格式 spring: profiles: active: prod #.properties格式 spring.profiles.active=dev

總結(jié)
以上所述是小編給大家介紹的spring boot開發(fā)遇到坑之spring-boot-starter-web配置文件使用教程,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
SpringBoot中@Configuration和@Bean和@Component相同點(diǎn)詳解
這篇文章主要介紹了SpringBoot中@Configuration和@Bean和@Component相同點(diǎn)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04
Java char[]數(shù)組轉(zhuǎn)成String類型詳細(xì)介紹
這篇文章詳細(xì)介紹了Java char[]數(shù)組轉(zhuǎn)成String類型(char to String)的方法,文章中有詳細(xì)的代碼示例,需要的朋友可以參考閱讀2023-04-04
Spring引入外部屬性文件配置數(shù)據(jù)庫連接的步驟詳解
這篇文章主要介紹了Spring引入外部屬性文件配置數(shù)據(jù)庫連接的步驟詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
詳解如何在Java中使用阿里云對(duì)象存儲(chǔ)OSS
Java是世界上最流行的編程語言之一,擁有著廣泛的應(yīng)用場景和強(qiáng)大的生態(tài)系統(tǒng),阿里云對(duì)象存儲(chǔ) OSS 是一種企業(yè)級(jí)的云存儲(chǔ)服務(wù),本文將介紹如何在 Java 中使用阿里云對(duì)象存儲(chǔ) OSS,并寫一點(diǎn)相應(yīng)的代碼示例供大家參考2023-06-06
spring boot+自定義 AOP 實(shí)現(xiàn)全局校驗(yàn)的實(shí)例代碼
最近公司重構(gòu)項(xiàng)目,重構(gòu)為最熱的微服務(wù)框架 spring boot, 重構(gòu)的時(shí)候遇到幾個(gè)可以統(tǒng)一處理的問題。這篇文章主要介紹了spring boot+自定義 AOP 實(shí)現(xiàn)全局校驗(yàn) ,需要的朋友可以參考下2019-04-04

