@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());
  }

原文地址:https://www.cnblogs.com/suizhikuo/p/9360031.html