中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

spring-boot-starter-web配置文件怎么用

發布時間:2021-08-10 11:46:41 來源:億速云 閱讀:131 作者:小新 欄目:編程語言

這篇文章主要介紹了spring-boot-starter-web配置文件怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

spring boot簡介

     spring boot是最近非常流行的,在spring的框架上改進的框架。該框架的目的是為了提高開發人員的速度,降低配置的難度等等,極大了簡化了開發流程。具體的詳細的說明請參考官方文檔。在日常工作中,由于需要搭建一套環境或者框架的機會非常的少,大部分都是在原有的基礎上開發,所以當讓你搭建一個簡單的框架,就會出現各種各樣的困難,比如說,我在搭建的一個服務器的時候,準備了一個小的demo,原以為非常的簡單,結果遇到了各種各樣的問題,而發現網上的博客都是零零散散的講一些點,很難有一個完整的流程,包括可能會遇到的問題。這里對搭建一個簡單的項目流程做一個詳細的總結,方便日后參考,同時這一篇博客也是為了下一篇博客tengine反向代理服務器搭建做一點前置的基礎準備。

Spring-boot的2大優點:

1.基于Spring框架的“約定優先于配置(COC)”理念以及最佳實踐之路。
2.針對日常企業應用研發各種場景的Spring-boot-starter自動配置依賴模塊,且“開箱即用”(約定spring-boot-starter- 作為命名前綴,都位于org.springframenwork.boot包或者命名空間下)。

本篇我將繼續向小伙伴介紹springboot配置文件的配置,已經全局配置參數如何使用,好了下面開始我們今天的內容介紹。

  我們知道Spring Boot支持容器的自動配置,默認是Tomcat,當然我們也是可以進行修改的:

  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容器了。

  為了方便我們的調試,這里給大家推薦一款http調試工具:Postman

  下面我們聊一下springboot的全局配置文件:application.properties

  在開發中一定遇到過這樣的需求,就是修改我們的容器訪問端口,既然springboot默認加載容器,那么端口設置當然是通過配置文件來控制的,相當方便我們只需要在配置文件中添加:

server.port=6666

  這樣我們的容器端口就修改為6666了。

  我們還可以通過配置文件來設置項目訪問別名:

server.context-path=/springboot

   這樣我們啟動項目通過http://localhost:6666/springboot1即可訪問到我們的項目

  以上只是springboot配置文件配置的冰山一角,比如我們還可以設置數據庫連接配置(database),設置開發環境配置,部署環境配置,實現兩者之間的無縫切換。

  下面我們一起了解一下關于springboot的controller的使用,springboot為我們提供了三個注解:

spring-boot-starter-web配置文件怎么用

  上一篇我們使用的便是@RestController,下面我們來一起使用@Controller試試:

@Controller
//@ResponseBody
public class RequestTest {
 /**
 * 不對請求方式限制
 * @return
 */
 @RequestMapping(value = "/req")
 public String req(){
 return "success";
 }
}

  當我們在瀏覽器輸入http://localhost:8080/springboot1/req回車,發現404

{
 "timestamp": 1515332935215,
 "status": 404,
 "error": "Not Found",
 "message": "No message available",
 "path": "/springboot1/req"
}

  這是為什么呢?這是因為@Controller必須配合模板使用,所以我們這里打開maven的pom文件,添加spingboot的模板:

<!-- springboot模板 -->
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

  然后在我們項目的resources目錄下找到templates(如過沒有,新建一個,但一定要注意文件夾名稱必須保持一致),然后創建一個success.html這樣我們再次啟動項目,訪問剛剛的地址,是不是就Ok了。

  不過這里需要說明一點,現在的企業級開發都是前后端分離,我們做后臺服務只需要返回對應的數據即可,當然使用模板還有一個弊端,那就是性能會造成一定的損耗,所以這里大家簡單了解即可。

  上面的介紹中已經說了,@Controller+@ResponseBody相當于@RestController,所以這里推薦大家使用@RestController。

  下面我們來介紹介紹一下@RequestMapping(value = "/req"),這個注解相信大家已經知道他的用法了,當然這個注解不但可以使用在方法上,同樣適用于類。

@RestController
//@Controller
//@ResponseBody
@RequestMapping(value = "/test")
public class RequestTest {
 /**
 * 不對請求方式限制
 * @return
 */
 @RequestMapping(value = "/req")
 public String req(){
 return "success";
 }
 /**
 * 限制請求方式為GET
 * @return
 */
 @RequestMapping(value = "/req1", method = RequestMethod.GET)
 public String req1(){
 return "success";
 }
 /**
 * 限制請求方式為POST
 * @return
 */
 @RequestMapping(value = "/req2", method = RequestMethod.POST)
 public String req2(){
 return "success";
 }
}

  對于method相信看到這里你一定已經知道他的用處了,是的指定訪問類型,沒有設置默認任何方式都可以訪問。不知道小伙伴是否想到如果在類的@RequestMapping設置過method那么類中的方法默認繼承,當然也可以在方法處單獨設定,優先級的問題,小伙伴自己嘗試一下吧。

  下面我將給大家介紹一下如何在Controller中的訪問配置文件中的常量。首先我們在配置文件中添加:

name=hpugs
age=35
content=name:${name};age:${age}

  我們在配置文件中使用常量,通過${}來使用。

  下面我們在Controller中將參數注入: 

 //注入配置文件中的參數
 @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;
 }

   啟動我們的項目訪問一下試試。

  這樣的使用如果你感覺還不過癮,這里再教大家一招:我們通過類映射配置文件,借助類來進行參數使用,相對單個參數注入要方便一些,首先創建一個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;
 }
}

  然后在我們的配置文件中設置參數:

userInfo.names=小破孩
userInfo.age=25
userInfo.content=name:${userInfo.names};age:${userInfo.age}

  接線來使我們的Controller:

 //注入對象
 @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();
 }

  好了重啟我們的項目訪問試試看。

  小伙伴們不知道遇到這個問題沒?出現了中文亂碼,首先大家先不要著急,我們先看另外一種springboot的配置文件:application.yml。這個配置文件通過換行空格來替換“;”,我們看一下同樣的配置在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}

  現在我們啟動項目運行試一試。

  回到上面的亂碼問題,當我們使用yml時是不是沒有出現亂碼,小伙伴是不是有點郁悶了,這是為什么呢?這是因為.properties文件使用的是unicode的編碼形式,所以當我們輸入中文時會出現亂碼。當然引亂碼的還有一種原因那就是我能的編碼設置和前端不一致,這個我們通過在配置文件中添加:

spring:
 http:
 encoding:
  force: true
  charset: UTF-8
 enabled: true
server:
 tomcat:
 uri-encoding: UTF-8

  來進行控制。這里再給大家介紹一下開發小技巧,springboot為我們提供了在不同開發環境下的不同配置文件解決方法:

#yml格式
spring:
 profiles:
 active: prod
#.properties格式
spring.profiles.active=dev

spring-boot-starter-web配置文件怎么用

感謝你能夠認真閱讀完這篇文章,希望小編分享的“spring-boot-starter-web配置文件怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

来凤县| 罗山县| 嘉兴市| 平南县| 宜良县| 蒲江县| 富锦市| 阜平县| 岗巴县| 调兵山市| 乌兰县| 宣恩县| 永吉县| 门源| 宽城| 武义县| 津市市| 西和县| 饶阳县| 宝清县| 太和县| 兖州市| 天峻县| 察隅县| 英超| 蓝田县| 遵义市| 新兴县| 德化县| 调兵山市| 大丰市| 霍林郭勒市| 久治县| 当阳市| 天全县| 舞钢市| 阳原县| 英山县| 玛纳斯县| 渭南市| 霍城县|