国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

SpringMVC之@RequestMapping詳解

2019-11-14 15:28:30
字體:
供稿:網(wǎng)友

(轉(zhuǎn)自:http://blog.csdn.net/walkerjong/article/details/7994326)

引言:

前段時間項目中用到了RESTful模式來開發(fā)程序,但是當(dāng)用POST、PUT模式提交數(shù)據(jù)時,發(fā)現(xiàn)服務(wù)器端接受不到提交的數(shù)據(jù)(服務(wù)器端參數(shù)綁定沒有加任何注解),查看了提交方式為application/json, 而且服務(wù)器端通過request.getReader() 打出的數(shù)據(jù)里確實存在瀏覽器提交的數(shù)據(jù)。為了找出原因,便對參數(shù)綁定(@RequestParam、 @RequestBody、 @RequestHeader 、 @PathVariable)進(jìn)行了研究,同時也看了一下HttpMessageConverter的相關(guān)內(nèi)容,在此一并總結(jié)。

 

簡介:

@RequestMapping

RequestMapping是一個用來處理請求地址映射的注解,可用于類或方法上。用于類上,表示類中的所有響應(yīng)請求的方法都是以該地址作為父路徑。

RequestMapping注解有六個屬性,下面我們把她分成三類進(jìn)行說明。

1、 value, method;

value:     指定請求的實際地址,指定的地址可以是URI Template 模式(后面將會說明);

method:  指定請求的method類型, GET、POST、PUT、DELETE等;

 

2、 consumes,PRoduces;

consumes: 指定處理請求的提交內(nèi)容類型(Content-Type),例如application/json, text/html;

produces:    指定返回的內(nèi)容類型,僅當(dāng)request請求頭中的(Accept)類型中包含該指定類型才返回;

 

3、 params,headers;

params: 指定request中必須包含某些參數(shù)值是,才讓該方法處理。

headers: 指定request中必須包含某些指定的header值,才能讓該方法處理請求。

 

示例:

1、value  / method 示例

默認(rèn)RequestMapping("....str...")即為value的值;

 1 @Controller 2 @RequestMapping("/appointments") 3 public class AppointmentsController { 4  5     private AppointmentBook appointmentBook; 6      7     @Autowired 8     public AppointmentsController(AppointmentBook appointmentBook) { 9         this.appointmentBook = appointmentBook;10     }11 12     @RequestMapping(method = RequestMethod.GET)13     public Map<String, Appointment> get() {14         return appointmentBook.getAppointmentsForToday();15     }16 17     @RequestMapping(value="/{day}", method = RequestMethod.GET)18     public Map<String, Appointment> getForDay(@PathVariable @DateTimeFormat(iso=ISO.DATE) Date day, Model model) {19         return appointmentBook.getAppointmentsForDay(day);20     }21 22     @RequestMapping(value="/new", method = RequestMethod.GET)23     public AppointmentForm getNewForm() {24         return new AppointmentForm();25     }26 27     @RequestMapping(method = RequestMethod.POST)28     public String add(@Valid AppointmentForm appointment, BindingResult result) {29         if (result.hasErrors()) {30             return "appointments/new";31         }32         appointmentBook.addAppointment(appointment);33         return "redirect:/appointments";34     }35 }

value的uri值為以下三類:

A) 可以指定為普通的具體值;

B)  可以指定為含有某變量的一類值(URI Template Patterns with Path Variables);

C) 可以指定為含正則表達(dá)式的一類值( URI Template Patterns with Regular Expressions);

example B:

1 @RequestMapping(value="/owners/{ownerId}", method=RequestMethod.GET)2 public String findOwner(@PathVariable String ownerId, Model model) {3   Owner owner = ownerService.findOwner(ownerId);  4   model.addAttribute("owner", owner);  5   return "displayOwner"; 6 }

example C:

1 @RequestMapping("/spring-web/{symbolicName:[a-z-]+}-{version:/d/./d/./d}.{extension:/.[a-z]}")2   public void handle(@PathVariable String version, @PathVariable String extension) {    3     // ...4   }5 }

2 consumes、produces 示例

cousumes的樣例:

@Controller@RequestMapping(value = "/pets", method = RequestMethod.POST, consumes="application/json")public void addPet(@RequestBody Pet pet, Model model) {        // implementation omitted}

方法僅處理request Content-Type為“application/json”類型的請求。

produces的樣例:

@Controller@RequestMapping(value = "/pets/{petId}", method = RequestMethod.GET, produces="application/json")@ResponseBodypublic Pet getPet(@PathVariable String petId, Model model) {        // implementation omitted}

方法僅處理request請求中Accept頭中包含了"application/json"的請求,同時暗示了返回的內(nèi)容類型為application/json;

3 params、headers 示例

params的樣例:

1 @Controller2 @RequestMapping("/owners/{ownerId}")3 public class RelativePathUriTemplateController {4 5   @RequestMapping(value = "/pets/{petId}", method = RequestMethod.GET, params="myParam=myValue")6   public void findPet(@PathVariable String ownerId, @PathVariable String petId, Model model) {    7     // implementation omitted8   }9 }

僅處理請求中包含了名為“myParam”,值為“myValue”的請求;

headers的樣例:

1 @Controller2 @RequestMapping("/owners/{ownerId}")3 public class RelativePathUriTemplateController {4 5 @RequestMapping(value = "/pets", method = RequestMethod.GET, headers="Referer=http://www.ifeng.com/")6   public void findPet(@PathVariable String ownerId, @PathVariable String petId, Model model) {    7     // implementation omitted8   }9 }

僅處理request的header中包含了指定“Refer”請求頭和對應(yīng)值為“http://www.ifeng.com/”的請求;

上面僅僅介紹了,RequestMapping指定的方法處理哪些請求,下面一篇將講解怎樣處理request提交的數(shù)據(jù)(數(shù)據(jù)綁定)和返回的數(shù)據(jù)。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 福鼎市| 陆川县| 余江县| 赤城县| 南京市| 金门县| 南皮县| 尉氏县| 高州市| 稻城县| 榆林市| 诏安县| 双牌县| 湘乡市| 施甸县| 韩城市| 墨竹工卡县| 邹城市| 文登市| 凤翔县| 萍乡市| 东辽县| 合作市| 砀山县| 电白县| 石林| 保康县| 泽普县| 武平县| 商水县| 恭城| 永吉县| 乾安县| 靖江市| 新安县| 金湖县| 静宁县| 封开县| 沙河市| 得荣县| 固阳县|