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