通常如果后端想响应json数据,我们需要在方法体上添加@Response注解,标注这个注解的方法的返回值会被spingmvc转为json形式并写入到响应体中。但ResponseEntity则不会被springmvc转换,可以使用这个类定义响应头,状态码,响应体等。
@Controller
public class ResponseBodyTest {
@ResponseBody
@GetMapping("b1")
public R b1(){
//将方法的返回值转为json写入到响应体中
return R.ok().put("msg","success");
}
@ResponseBody
@GetMapping("b2")
public ResponseEntity<String> b2(){
HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.setContentType(MediaType.TEXT_PLAIN);
String str = "hello,world";
ResponseEntity responseEntity = new ResponseEntity<String>(str,httpHeaders,HttpStatus.OK);
return responseEntity;
}
}
我们 /b2 请求设置了@ResponseBody注解,但由于返回的是ResponseEntity对象,而且我们又重新设置了响应类型为 text/plain,我们访问b2请求查看结果:
总结:
ResponseEntity的优先级高于@ResponseBody。在不是ResponseEntity的情况下才去检查有没有@ResponseBody注解。如果响应类型是ResponseEntity可以不写@ResponseBody注解,写了也没有关系。简单的说@ResponseBody可以直接返回Json结果, @ResponseEntity不仅可以返回json结果,还可以定义返回的HttpHeaders和HttpStatus。