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