Springboot 2.x中server.servlet.context-path的運用詳解
今天在開發項目的時候遇到瞭請求不通API的問題,最開始以為是server.servlet.context-path配置導致的問題,最終發現是由於AWS端口未開放/監聽導致的connection refuse。雖然如此,仍然想記錄一下server.servlet.context-path的作用。
功能
這個配置能夠設置項目中的所有API的上下文路徑(URL的一部分),與@RequestMapping有異曲同工之妙。
我們知道,@RequestMapping能夠在API方法層級聲明,同時能夠在Controller的類層級聲明,為什麼能夠在多層級聲明呢?大傢很容易想到,為瞭使API url的語義性,遵從REST標準的API是非常棒的,同一個Controller下的URL前綴相同能夠非常明確的表達語義與關聯關系。
那麼,如果我們有多個項目/微服務呢?也應該做到這一點,隻不過是以更大的層級方式在應用。server.servlet.context-path能夠以一個project為單位配置默認的URL上下文路徑,保持設計的一致性是非常合適的做法。
用法
如果我們沒有添加任何配置,則為默認值“/”,
我們可以在Springboot的properties下配置:
server.servlet.context-path=/api/demo
如果使用的是yml配置方式,則為:
server: servlet: context-path:/api/demo
那麼我們調用一個地址本來為 [ip地址]:[端口號]/books 的API,現在變成瞭 [ip地址]:[端口號]/api/demo/books
註意!!! 配置上有一個小坑,如果你使用的是Springboot 1.x版本,我們需要改為使用 server.context-path 來配置路徑。
優點
- 我們能夠通過此配置在更大的層級上做統一的路徑配置,體現瞭RESTFul的語義化API URL的優勢。
- 便於配置Ngnix的請求分發
SpringBoot2.X配置server.context-path不生效的解決
之前看視頻教程的時候發現教程上的配置是這樣的
server.context-path=/IMooc
然後我按照這樣配置發現重啟瞭並未生效
Tomcat started on port(s): 8081 (http) with context path ”
後來百度發現原來1.X版本這樣配置是可以的,但是2.X版本需要如下配置才能生效
server.servlet.context-path=/Daojihe Tomcat started on port(s): 8081 (http) with context path '/Daojihe'
到此這篇關於Springboot 2.x中server.servlet.context-path的運用詳解的文章就介紹到這瞭,更多相關Springboot 2.x server.servlet.context-path內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- springBoot server.port=-1的含義說明
- springboot 如何設置端口號和添加項目名
- 使用IDEA開發配置Java Web的初始化過程
- springboot 如何修改默認端口及application.properties常用配置
- springboot啟動時如何獲取端口和項目名