一、简言
在spring boot的开发中常常会用到注解 @RequestParam、@PathVariable、@RequestBody、@PageableDefault、@RequestMapping、@GetMapping 和 @PostMapping定义提供给前端的接口函数。下面将会对这些注解进行说明。
二、注解说明
@PathVariable :绑定URI模板变量值,用来获得url中的动态参数值。使用示例参考如下:
提供给前端的URL:
http://localhost:8080/springmvc/hello/101?param1=10¶m2=20
后端接口代码如下:
@RequestMapping("/hello/{id}")
public String getDetails(@PathVariable(value="id") String id,
@RequestParam(value="param1", required=true) String param1,
@RequestParam(value="param2", required=false) String param2){
.......
}
在后端的接口定义中,定义了三个参数id,param1,param2。
@RequestParam:从request里面拿取值。使用示例参考如下:
提供给前端的URL:
http://localhost:8080/springmvc/hello/101?param1=10¶m2=20
后端提供的接口代码如下:
public String getDetails(
@RequestParam(value="param1", required=true) String param1,
@RequestParam(value="param2", required=false) String param2){
...
}
@RequestParam支持四种参数
- defaultValue如果本次请求没有携带这个参数,或者参数为空,那么就启用默认值。
- name绑定本次参数的名称,要跟URL上面的一样
- required这个参数表明,参数值是不是必须的,true表示必须不能为空,false表示不是必须可以为空
- value 跟name一样的作用,是name属性的一个别名。
@RequestBody :主要用来处理Content-Type是application/json,application/xml的Json字符串。多用在Post类型请求中。
Pageable:是Spring Data库中定义的一个接口,该接口是所有分页相关信息的一个抽象,通过该接口我们可以得到和分页相关所有信息,其中比较重要的信息包括两个:一个分页的信息,一个是排序的信息。
page:第几页,从0页开始,默认为第0也
size:每一页的大小,默认为20
sort:排序相关信息,以property,property(ASC|DESC)的方式组织,例如sort=firstname&sort=lastname,desc表示
@PageableDefault:表示spring data提供给我们个性化设置pageable默认配置。比如@PageableDefault(value = 15, sort = {“id”}, direction = Sort.Direction.DESC)就表示默认情况下我们按照id倒序排列,每一页的大小为15。
@ResponseBody
@RequestMapping(value = "list", method=RequestMethod.GET)
public Page<blog> listByPageable(@PageableDefault(value = 15, sort = { "id" }, direction = Sort.Direction.DESC)
Pageable pageable) {
return blogRepository.findAll(pageable);
}
@RequestMapping :主要将HTTP请求映射到MVC和REST控制器的处理方法上,可以具体细分为一下几类:
1.将特定的请求或者请求模式映射到一个控制器上,甚至还可以具体到方法级别的映射上,参考如下:
@RestController
@RequestMapping("/home") // /home/*的请求会由IndexController 进行处理
public class IndexController {
@RequestMapping("/") // /home的请求会由get()方法来处理
String get() {
//mapped to hostname:port/home/
return "Hello from get";
}
@RequestMapping("/index") // /home/index的请求会由index()来处理
String index() {
//mapped to hostname:port/home/index/
return "Hello from index";
}
}
2.可以处理多个URL,比如将多个请求映射到一个方法上去,参考如下:
@RestController
@RequestMapping("/home")
public class IndexController {
@RequestMapping(value = {
"",
"/page",
"page*",
"view/*,**/msg"
})
String indexMultipleMapping() {
return "Hello from index multiple mapping.";
}
}
在上述代码中,如下URL都会由indexMultipleMapping()来处理:
/home
/home/
/home/page
/home/pageabc
/home/view/
/home/view/view
3.用@RequestMapping处理HTTP的各种方法,如GET、PUT、POST、DELETE以及PATCH。以POST的方法为例,参考如下:
@RestController
@RequestMapping("/home")
public class IndexController {
@RequestMapping(method = RequestMethod.POST)
String post() {
return "Hello from post";
}
}
4.@RequestMapping可以通过定义生产对象produces和消费对象consumes来进一步缩小映射类型的范围。参考如下:
@RestController
@RequestMapping("/home")
public class IndexController {
@RequestMapping(value = "/prod", produces = {
"application/JSON"
})
@ResponseBody
String getProduces() { //getProduces()方法会产生一个JSON的响应
return "Produces attribute";
}
@RequestMapping(value = "/cons", consumes = {
"application/JSON",
"application/XML"
})
String getConsumes() { //getCOnsumes()方法可以同时处理请求中的JSON和XML内容
return "Consumes attribute";
}
}
@GetMapping和@PutMapping:是@RequestMapping的快捷方式,比如@GetMapping所扮演的是@RequestMapping(method=RequestMethod.GET)的一个快捷方式。