@PathVariable為空時指定默認(rèn)值的操作
@PathVariable為空時指定默認(rèn)值,
可以指定多個匹配路徑,然后設(shè)置參數(shù)非必要的,就可以了,例子如下
@RequestMapping(value = {"/timeline/{uid}", "/timeline/{uid}/{size}"}) public ModelAndView getTimeline(@PathVariable(value="uid" ) String articleUserId, @PathVariable(value="size" , required = false) Integer size, ModelAndView modelAndView) { if(size == null) size = 50; //邏輯 }
對于下面兩種URL都是可以處理的
http://www.leixingke.com/article/timeline/leixing
http://www.leixingke.com/article/timeline/leixing/100
補充:@PathVariable設(shè)置為空的問題(required=false)
最近學(xué)習(xí)springMVC的時候,學(xué)到@PathVariable后,發(fā)現(xiàn)@PathVariable有個required屬性,于是將其設(shè)置為false,發(fā)現(xiàn)訪問請求時報錯。
剛開始我的代碼是這樣的:
@RequestMapping(value={"/user/{id}/{name}"}) public User getUser(@PathVariable(value="id",required=false) Integer id,@PathVariable(value="name",required=false) String name ){ System.out.println("--------------:"+id+","+name); User user=new User(id,name); return user; }
后面發(fā)現(xiàn)上面的文章,將方法改成如下就可以了:
/** * http://localhost:8080/helloWorld/user/1/zhangsan * http://localhost:8080/helloWorld/user/1 * http://localhost:8080/helloWorld/user * @param id * @param name * @return */ @RequestMapping(value={"/user/{id}/{name}","/user/{id}","/user"}) public User getUser(@PathVariable(value="id",required=false) Integer id,@PathVariable(value="name",required=false) String name ){ System.out.println("--------------:"+id+","+name); User user=new User(id,name); return user; }
原因就是地址是不一樣的,需要配置多個地址映射。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
詳解SpringBoot定制@ResponseBody注解返回的Json格式
這篇文章主要介紹了詳解SpringBoot定制@ResponseBody注解返回的Json格式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11SpringBoot Security前后端分離登錄驗證的實現(xiàn)
這篇文章主要介紹了SpringBoot Security前后端分離登錄驗證的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09使用lombok的@Data會導(dǎo)致棧溢出StackOverflowError問題
這篇文章主要介紹了使用lombok的@Data會導(dǎo)致棧溢出StackOverflowError問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11SpringBoot項目接入Nacos的實現(xiàn)步驟
SpringBoot項目使用nacos作為配置中心和服務(wù)注冊中心,同時兼容dubbo的注冊中心。 本Demo項目使用的SpringBoot版本是2.3.9.RELEASE2021-05-05實戰(zhàn)SpringBoot集成JWT實現(xiàn)token驗證
本文詳細講解了SpringBoot集成JWT實現(xiàn)token驗證,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12