@Controller和@RestController的区别
二者区别
可以分别进到两个注解的代码中,看下二者代码有什么区别,如下。
@Controller
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Component
public @interface Controller {
String value() default "";
}
- @RestController
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Controller
@ResponseBody
public @interface RestController {
String value() default "";
}
根据这段代码可以看出,@RestController相对于@Controller多了一个@ResponseBody。和 官方文档的描述 基本相同,即使用@RestController可以被看做同时使用了@Controller和@ResponseBody注解。每个@RequestMapping方法默认使用了@ResponseBody注解。
使用时机
因此在具体的使用时需要根据实际要求来选择:
- @Controller,在需要视图解析器InternalResourceViewResolver来返回指定页面时使用@Controller注解。
- @RestController,在不需要返回页面,只需要某种格式的数据(json、xml)时使用@RestController注解。
@responseBody注解的使用
1、
@responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML
数据,需要注意的呢,在使用此注解之后不会再走视图处理器,而是直接将数据写入到输入流中,他的效果等同于通过response对象输出指定格式的数据。
2、
@RequestMapping("/login")
@ResponseBody
public User login(User user){
return user;
}
User字段:userName pwd
那么在前台接收到的数据为:'{"userName":"xxx","pwd":"xxx"}'
效果等同于如下代码:
@RequestMapping("/login")
public void login(User user, HttpServletResponse response){
response.getWriter.write(JSONObject.fromObject(user).toString());
}