您好,登錄后才能下訂單哦!
經(jīng)過上一篇的介紹,相信小伙伴們已經(jīng)按奈不住內(nèi)心對springboot的向往,本篇我將繼續(xù)向小伙伴介紹springboot配置文件的配置,已經(jīng)全局配置參數(shù)如何使用,好了下面開始我們今天的內(nèi)容介紹。
我們知道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容器了。
為了方便我們的調(diào)試,這里給大家推薦一款http調(diào)試工具:Postman
下面我們聊一下springboot的全局配置文件:application.properties
在開發(fā)中一定遇到過這樣的需求,就是修改我們的容器訪問端口,既然springboot默認加載容器,那么端口設(shè)置當然是通過配置文件來控制的,相當方便我們只需要在配置文件中添加:
server.port=6666
這樣我們的容器端口就修改為6666了。
我們還可以通過配置文件來設(shè)置項目訪問別名:
server.context-path=/springboot1
這樣我們啟動項目通過http://localhost:6666/springboot1即可訪問到我們的項目
以上只是springboot配置文件配置的冰山一角,比如我們還可以設(shè)置數(shù)據(jù)庫連接配置(database),設(shè)置開發(fā)環(huán)境配置,部署環(huán)境配置,實現(xiàn)兩者之間的無縫切換?! ?br />
下面我們一起了解一下關(guān)于springboot的controller的使用,springboot為我們提供了三個注解:
上一篇我們使用的便是@RestController,下面我們來一起使用@Controller試試:
@Controller //@ResponseBody public class RequestTest { /** * 不對請求方式限制 * @return */ @RequestMapping(value = "/req") public String req(){ return "success"; } }
當我們在瀏覽器輸入http://localhost:8080/springboot1/req回車,發(fā)現(xiàn)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(如過沒有,新建一個,但一定要注意文件夾名稱必須保持一致),然后創(chuàng)建一個success.html這樣我們再次啟動項目,訪問剛剛的地址,是不是就Ok了。
不過這里需要說明一點,現(xiàn)在的企業(yè)級開發(fā)都是前后端分離,我們做后臺服務(wù)只需要返回對應(yīng)的數(shù)據(jù)即可,當然使用模板還有一個弊端,那就是性能會造成一定的損耗,所以這里大家簡單了解即可。
上面的介紹中已經(jīng)說了,@Controller+@ResponseBody相當于@RestController,所以這里推薦大家使用@RestController。
下面我們來介紹介紹一下@RequestMapping(value = "/req"),這個注解相信大家已經(jīng)知道他的用法了,當然這個注解不但可以使用在方法上,同樣適用于類。
@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相信看到這里你一定已經(jīng)知道他的用處了,是的指定訪問類型,沒有設(shè)置默認任何方式都可以訪問。不知道小伙伴是否想到如果在類的@RequestMapping設(shè)置過method那么類中的方法默認繼承,當然也可以在方法處單獨設(shè)定,優(yōu)先級的問題,小伙伴自己嘗試一下吧。
下面我將給大家介紹一下如何在Controller中的訪問配置文件中的常量。首先我們在配置文件中添加:
name=hpugs age=35 content=name:${name};age:${age}
我們在配置文件中使用常量,通過${}來使用。
下面我們在Controller中將參數(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; }
啟動我們的項目訪問一下試試。
這樣的使用如果你感覺還不過癮,這里再教大家一招:我們通過類映射配置文件,借助類來進行參數(shù)使用,相對單個參數(shù)注入要方便一些,首先創(chuàng)建一個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:
//注入對象 @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àn)了中文亂碼,首先大家先不要著急,我們先看另外一種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}
現(xiàn)在我們啟動項目運行試一試。
回到上面的亂碼問題,當我們使用yml時是不是沒有出現(xiàn)亂碼,小伙伴是不是有點郁悶了,這是為什么呢?這是因為.properties文件使用的是unicode的編碼形式,所以當我們輸入中文時會出現(xiàn)亂碼。當然引亂碼的還有一種原因那就是我能的編碼設(shè)置和前端不一致,這個我們通過在配置文件中添加:
spring: http: encoding: force: true charset: UTF-8 enabled: true server: tomcat: uri-encoding: UTF-8
來進行控制。這里再給大家介紹一下開發(fā)小技巧,springboot為我們提供了在不同開發(fā)環(huán)境下的不同配置文件解決方法:
#yml格式 spring: profiles: active: prod #.properties格式 spring.profiles.active=dev
總結(jié)
以上所述是小編給大家介紹的SpringBoot入坑筆記之spring-boot-starter-web 配置文件的使用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。