开发RESTful API 时,通常都会在Controller上加上@Controller注解,可是有时候加上@RestController,当同事问为何的时候,我也一脸懵逼,默默的看了资料,如今就说说他们的区别。html
@RestController注解等价于@ResponseBody + @Controller。@RestController和@Controller的共同点是都用来表示Spring某个类是否能够接收HTTP请求,两者区别: @RestController没法返回指定页面,而@Controller能够;前者能够直接返回数据,后者须要@ResponseBody辅助。下面详细分析。java
① 是否能够返回页面web
答:@RestController没法返回指定页面,而@Controller能够。
解析:对于Controller, 若是只是使用@RestController注解,则其方法没法返回指定页面,此时配置的视图解析器 InternalResourceViewResolver不起做用,返回的内容就是 return 里的内容。 若是须要返回到指定页面,则须要用 @Controller配合视图解析器InternalResourceViewResolver才行。
② 返回内容
若是须要返回JSON,XML或自定义mediaType内容到页面,@RestController本身就能够搞定,这个注解对于返回数据比较方便,由于它会自动将对象实体转换为JSON格式。而@Controller须要在对应的方法加上@ResponseBody注解。spring
示例:json
import java.util.HashMap; import java.util.Map; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/difference") public class DifferenceController { // 跳转到上传文件的页面 @RequestMapping(value = "/goToSuccessPage", method = RequestMethod.GET) public String goToSuccessPage() { // 跳转到 视图层 success.html return "success"; } @RequestMapping(value = "findAll", method = RequestMethod.GET) public Map<String, String> findAll() { Map<String, String> all = new HashMap<>(); all.put("remark", "能够返回json,xml或自定义mediaType内容到页面"); return all; } }