Springmvc一些前后端交互需要用到的注解的详细说明
1.@Controller和@RestController
@RestController注解相当于@ResponseBody + @Controller合在一起的作用
) 如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,或者html,配置的视图解析器 InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。
- 如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行。
如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解。
举例: @Controller
1.使用@Controller 注解,在对应的方法上,视图解析器可以解析return 的jsp,html页面,并且跳转到相应页面
若返回json等内容到页面,则需要加@ResponseBody注解
1.使用@Controller跳转到相应的页面去
@CrossOrigin
@Controller
public class FileUploadController {
//跳转到上传文件的页面
@RequestMapping(value="/gouploadimg", method = RequestMethod.GET)
public String goUploadImg() {
//跳转到 templates 目录下的 uploadimg.html
return "uploadimg"; //返回的结果是 视图,一个页面 。 这个要自己写相关的 hello.jsp 页面 , 并且配置 ViewResolver 视图解析器
}
2.返回具体的内容到jsp页面上去
/**
* 返回json 格式的数据
*
* @param name
* @return
*/
@RequestMapping(value = "/world", method = RequestMethod.GET)
@ResponseBody
public String returnJson(String name) {
System.out.println("name : " + name);
return "hello"; //GET方法 , 在方法前加了 @ResponeBody 注解 ,返回json 格式的数据 。不需要配置视图解析器。
}
举例 @RestController
@RestController注解,相当于@Controller+@ResponseBody两个注解的结合,返回json数据不需要在方法前面加@ResponseBody注解了,但使用@RestController这个注解,就不能返回jsp,html页面,视图解析器无法解析jsp,html页面
@CrossOrigin
@RestController
@RequestMapping(value = "/rest", produces = {
MediaType.APPLICATION_JSON_VALUE, MediaType.APPLICATION_XML_VALUE})
public class RestHelloController {
/**
* get method
*
* @param name
* @return
*/
@RequestMapping(value = "/hello", method = RequestMethod.GET)
public String hello