Springboot 2.x中server.servlet.context-path的運用詳解
今天在開發(fā)項目的時候遇到了請求不通API的問題,最開始以為是server.servlet.context-path配置導(dǎo)致的問題,最終發(fā)現(xiàn)是由于AWS端口未開放/監(jiān)聽導(dǎo)致的connection refuse。雖然如此,仍然想記錄一下server.servlet.context-path的作用。
功能這個配置能夠設(shè)置項目中的所有API的上下文路徑(URL的一部分),與@RequestMapping有異曲同工之妙。
我們知道,@RequestMapping能夠在API方法層級聲明,同時能夠在Controller的類層級聲明,為什么能夠在多層級聲明呢?大家很容易想到,為了使API url的語義性,遵從REST標準的API是非常棒的,同一個Controller下的URL前綴相同能夠非常明確的表達語義與關(guān)聯(lián)關(guān)系。
那么,如果我們有多個項目/微服務(wù)呢?也應(yīng)該做到這一點,只不過是以更大的層級方式在應(yīng)用。server.servlet.context-path能夠以一個project為單位配置默認的URL上下文路徑,保持設(shè)計的一致性是非常合適的做法。
用法如果我們沒有添加任何配置,則為默認值“/”,我們可以在Springboot的properties下配置:
server.servlet.context-path=/api/demo
如果使用的是yml配置方式,則為:
server: servlet: context-path:/api/demo
那么我們調(diào)用一個地址本來為 [ip地址]:[端口號]/books 的API,現(xiàn)在變成了 [ip地址]:[端口號]/api/demo/books
注意!!! 配置上有一個小坑,如果你使用的是Springboot 1.x版本,我們需要改為使用 server.context-path 來配置路徑。
優(yōu)點 我們能夠通過此配置在更大的層級上做統(tǒng)一的路徑配置,體現(xiàn)了RESTFul的語義化API URL的優(yōu)勢。 便于配置Ngnix的請求分發(fā)SpringBoot2.X配置server.context-path不生效的解決之前看視頻教程的時候發(fā)現(xiàn)教程上的配置是這樣的
server.context-path=/IMooc
然后我按照這樣配置發(fā)現(xiàn)重啟了并未生效
Tomcat started on port(s): 8081 (http) with context path ’’
后來百度發(fā)現(xiàn)原來1.X版本這樣配置是可以的,但是2.X版本需要如下配置才能生效
server.servlet.context-path=/DaojiheTomcat started on port(s): 8081 (http) with context path ’/Daojihe’
到此這篇關(guān)于Springboot 2.x中server.servlet.context-path的運用詳解的文章就介紹到這了,更多相關(guān)Springboot 2.x server.servlet.context-path內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. jsp+mysql實現(xiàn)網(wǎng)頁的分頁查詢2. Docker 部署 Prometheus的安裝詳細教程3. JavaScript Tab菜單實現(xiàn)過程解析4. ThinkPHP5 通過ajax插入圖片并實時顯示(完整代碼)5. Python使用oslo.vmware管理ESXI虛擬機的示例參考6. IntelliJ IDEA設(shè)置條件斷點的方法步驟7. Ajax引擎 ajax請求步驟詳細代碼8. Android實現(xiàn)圖片自動切換功能(實例代碼詳解)9. javascript設(shè)計模式 ? 建造者模式原理與應(yīng)用實例分析10. 存儲于xml中需要的HTML轉(zhuǎn)義代碼
