@Controller 和 @RestController 的区别

@RestController 注解相当于 @ResponseBody + @Controller 合在一起的作用

1) 如果只是使用 @RestController 注解 Controller,则 Controller 中的方法无法返回 jsp 页面,配置的视图解析器 InternalResourceViewResolver 不起作用,返回的内容就是 Return 里的内容。

例如:本来应该到 success.jsp 页面的,则其显示 success.

2) 如果需要返回到指定页面,则需要用 @Controller 配合视图解析器 InternalResourceViewResolver 才行。

3) 如果需要返回 JSON,XML 或自定义 mediaType 内容到页面,则需要在对应的方法上加上 @ResponseBody 注解。

 

1. 使用 @Controller 注解,

在对应的方法上,视图解析器可以解析 return 的 jsp,html 页面,并且跳转到相应页面

若返回 json 等内容到页面,则需要加 @ResponseBody 注解

@CrossOrigin
@Controller 
public class FileUploadController { 
//跳转到上传文件的页面
@RequestMapping(value="/gouploadimg", method = RequestMethod.GET)
 public String goUploadImg() {
 //跳转到 templates 目录下的 uploadimg.html
return "uploadimg";
} 
//处理文件上传
@RequestMapping(value="/testuploadimg", method = RequestMethod.POST) 
public @ResponseBody String uploadImg(@RequestParam("file") MultipartFile file,
HttpServletRequest request) {
System.out.println("调用文件上传方法");
String contentType = file.getContentType();
String fileName = file.getOriginalFilename();

 }
}

  2.@RestController 注解

相当于 @Controller+@ResponseBody 两个注解的结合,返回 json 数据不需要在方法前面加 @ResponseBody 注解了,但使用 @RestController 这个注解,就不能返回 jsp,html 页面,视图解析器无法解析 jsp,html 页面

@CrossOrigin
@RestController /* @Controller + @ResponseBody*/
public class HospitalController { 
//注入Service服务对象
 @Autowired 
private HospitalService hospitalService;
 /** * 查询所有医院信息(未分页) */ 
@RequestMapping(value = "findAllHospital",method = RequestMethod.GET) 
public  List<Hospital> findAllHospital(){
        List<Hospital> hospitalList= hospitalService.findAllHospital(); return hospitalList;
    }
}