目录
@RequestBody
作用:
则是将 HTTP 请求正文插入方法中,使用适合的 HttpMessageConverter 将请求体写入某个对象。
用于将前台发送过来固定格式的数据【xml格式 或者 json等】封装为对应的 JavaBean 对象,
位置:
是作用在形参列表上,只写一遍
使用时机
当前端通过POST发送数据
原理:
该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定
到要返回的对象上;再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上。
@RequestMapping(value = {"/test1","test2"},method = RequestMethod.GET)
@ResponseBody
public String TestController1(@RequestBody String book){
System.out.println(book);
return book;
}
@RequestParam
作用:
用于将请求参数的值绑定到方法的参数上。它通常用于处理 HTTP 请求中的查询参数或表单参数。
位置:
是作用在形参列表上(每个参数写一个)
属性:
1.value
@RequestParam可以通过@RequestParam(“userId”)或@RequestParam(value = “userId”)指定传入的参数名。(最主要的作用)
2.defaultValue = “0”
@RequestParam可以通过@RequestParam(defaultValue = “0”)指定参数默认值
不传参就是默认值
3.required = false
不加@RequestParam参数为非必传,加@RequestParam写法参数为必传。但@RequestParam可以通过@RequestParam(required = false)设置为非必传。
注意:
- 不加@RequestParam前端的参数名需要和后端控制器的变量名保持一致才能生效
- 如果接口除了前端调用还有后端RPC调用,则不能省略@RequestParam,否则RPC会找不到参数报错
- Get方式请求,参数放在url中时:
不加@RequestParam注解:url可带参数也可不带参数,输入 localhost:8080/test 以及 localhost:8080/test?userId=xxx 方法都能执行
加@RequestParam注解:url必须带有参数。也就是说你直接输入localhost:8080/test 会报错,不会执行方法。只能输入localhost:8080/list2?userId=xxx 才能执行相应的方法
@RequestMapping(value = {"/test1","test2"},method = RequestMethod.GET)
@ResponseBody
public String TestController1(@RequestParam(value = "book",required = false,defaultValue = "默认值") String book){
System.out.println(book);
return book;
}