@ResponseBody和@RequestBody注解的区别
在了解@ResponseBody和@RequestBody之前先来了解@RequestMapping
先了解@RequestMapping
@RequestMapping 是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径;用于方法上,表示在类的父路径下追加方法上注解中的地址将会访问到该方法,此处需注意@RequestMapping用在类上可以没有,但是用在方法上必须有。
@Controller
@RequestMapping("/parent")
public class testController {
@RequestMapping("test1")
public String test1() {
return "test2";
}
@RequestMapping("test2")
public void test2() {
System.out.println("Hello World!");
}
}
在本地服务器上访问方法http://localhost:8080/parent/test1就会返回跳转到http://localhost:8080/parent/test2页面从而在控制台输出Hello World!
。
@ResponseBody
@Responsebody 注解一般在异步获取数据时使用,通常是在使用 @RequestMapping 后,返回值通常解析为跳转路径,加上 @Responsebody 后返回结果不会被解析为跳转路径,而是直接写入HTTP 响应正文中。
作用
该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。
使用时机
返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用;
@Controller
@RequestMapping("/parent")
public class testController {
@RequestMapping("test1")
@ResponseBody // 此时加上注解@ResponseBody就不会将test2解析为跳转路径而是直接将字符串回显到浏览器上
public String test1() {
return "test2";
}
@RequestMapping("test2")
public void test2() {
System.out.println("Hello World!");
}
}
@RequestBody
@RequestBody 是作用于方法的参数中,将请求体以json形式写入某个对象。
作用
- 该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定到要返回的对象上;
- 再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上。
测试
- 创建User类
@Data // 使用了lombok
@AllArgsConstructor
@NoArgsConstructor
public class User {
private Integer id;
private String name;
private Integer age;
}
- 编写controller类
@RestController
public class testController {
@PostMapping("test")
public void test(@RequestBody User user) {
System.out.println(user.toString());
}
}
- 使用swagger测试,也可以使用postman
- 测试结果