@RestController註解相當於@ResponseBody+@Controller合在一起的作用
- 如果只是使用@RestController註解Controller,則Controller中的方法無法返回jsp頁面,或者html,配置的視圖解析器InternalResourceViewResolver不起作用,返回的內容就是Return裏的內容.
- 如果需要返回到指定頁面,則需要用@Controller配合視圖解析器InternalResourceViewResolver纔行,如果需要返回JSON,XML或自定義mediaType內容到頁面,則需要在對應的方法上加上@ResponseBody註解.
Controller
使用@Controller註解,在對應的方法上,視圖解析器可以解析return的jsp,html頁面,並且跳轉到相應頁面
若返回json等內容到頁面,則需要加@ResponseBody註解
@Controller
public class FileUploadController {
//跳轉到上傳文件的頁面
@GetMapping(value="gouploadimg")
public String goUploadImg() {
//跳轉到 templates 目錄下的 uploadimg.html
return "uploadimg";
}
//處理文件上傳
@PostMapping(value="testuploadimg")
public @ResponseBody String uploadImg(@RequestParam("file") MultipartFile file, HttpServletRequest request) {
System.out.println("調用文件上傳方法");
String contentType = file.getContentType();
String fileName = file.getOriginalFilename();
....
}
}
RestController
@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;
}
ResponseBody
@ResponseBody註解的作用是將controller的方法返回的對象通過適當的轉換器轉換爲指定的格式之後,寫入到response對象的body區,通常用來返回JSON數據或者是XML數據,需要注意的呢,在使用此註解之後不會再走試圖處理器,而是直接將數據寫入到輸入流中,他的效果等同於通過response對象輸出指定格式的數據
@RequestMapping("/login")
@ResponseBody
public User login(User user){
return user;
}
User字段:userName pwd 那麼在前臺接收到的數爲:{"userName":"xxx","pwd":"xxx"}
效果等同於如下代碼:
@RequestMapping("/login")
public void login(User user, HttpServletResponse response){
response.getWriter.write(JSONObject.fromObject(user).toString());
}