restcontroller與controller區別
知識點:@RestController註解相當於@ResponseBody + @Controller合在一起的作用。
1) 如果只是使用@RestController註解Controller,則Controller中的方法無法返回jsp頁面,或者html,配置的檢視解析器 InternalResourceViewResolver不起作用,返回的內容就是Return 裡的內容。
2) 如果需要返回到指定頁面,則需要用 @Controller配合檢視解析器InternalResourceViewResolver才行。
如果需要返回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();
[email protected]註解,相當於@[email protected]兩個註解的結合,返回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; }