基本介绍
-
@requestparam
属性介绍
- required:表示是否必须,默认为
true
,必须 - defaultValue:可设置请求参数的默认值
- value:为接收url的参数名(相当于key值)
-
@requestbody
属性介绍
- required:表示是否必须,默认为
true
,必须
使用方式
@requestparam
@RequestParam用来处理 Content-Type:
application/x-www-form-urlencoded
编码的内容,Content-Type
默认为该属性。@RequestParam也可用于其它类型的请求,例如:POST、DELETE等请求。但是这样不支持批量插入数据,如果改用json
字符串来传值的话,类型设置为 application/json
,点击发送的话,会报错,后台接收不到值,为null
。这时候,注解@RequestBody就派上用场了。
注意:方法中参数类型为实体时不能够使用@RequestParam,否则会报400的错误。当然如果把@RequestParam(required = false)加到试题类型参数前面,就不会报错,但是实体类也不会被赋值。
@GetMapping("test1") @ResponseBody public String test1(String userName, Integer age) { return "姓名:" + userName + ",年龄:" + age; } @GetMapping("test2") @ResponseBody public String test2(UserEntity userEntity, String userName, Integer age) { return "用户:" + JSONUtil.toJsonStr(userEntity) + "姓名:" + userName + ",年龄:" + age; } @GetMapping("test3") @ResponseBody public String test3(UserEntity userEntity, @RequestParam(name = "name", required = false) String userName,Integer age) { return "用户:" + JSONUtil.toJsonStr(userEntity) + "姓名:" + userName + ",年龄:" + age; }
@requestbody
注解@RequestBody接收的参数是来自requestBody中,即请求体。一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/json、application/xml等类型的数据。就application/json
类型的数据而言,使用注解@RequestBody可以将body里面所有的json数据传到后端,后端再进行解析
GET请求中,因为没有HttpEntity,所以@RequestBody并不适用。
POST请求中,通过HttpEntity传递的参数,必须要在请求头中声明数据的类型Content-Type,SpringMVC通过使用HandlerAdapter 配置的HttpMessageConverters来解析HttpEntity中的数据,然后绑定到相应的bean上。
注意:前端使用$.ajax的话,一定要指定 contentType: "application/json;charset=utf-8;"
,默认为 application/x-www-form-urlencoded
。
@PostMapping("test4")
@ResponseBody
public String test4(@RequestBody List<UserEntity> lists) {
return "用户:" + JSONUtil.toJsonStr(lists);
}
@PostMapping("test5")
@ResponseBody
public String test5(@RequestBody List<Map<String, Object>> maps) {
return "用户:" + JSONUtil.toJsonStr(maps);
}
通过postman正确调用:
如果使用form表单提交,就会报错: