首先这个注解是用在类上的, 表示类中的所有的方法都是rest风格的,方法的返回值都是json, (大部分是对的,感觉是jsackson 吧,而不是fastjson 吧)
(json 是结构化的数据啊,所以这个网站才可以解析啊https://www.json.cn/)
API 返回的数据格式,不应该是纯文本,而应该是一个 JSON 对象,因为这样才能返回标准的结构化数据。所以,服务器回应的 HTTP 头的Content-Type属性要设为application/json。
而且是前端才有这样的http,所以rest 回和control 进行绑定,而不是和service 绑定,所以产生了restController, 也只有在controll 这层有严格的增删改查
链接:https://www.jianshu.com/p/0e7e379afc6f
SpringBoot仍然秉承MVC的架构,在注解命名方面遵循此类讲究,对于负责Restful API交互的功能模块,SpingBoot采用@RestController在修饰类
@RestController = @Controller + @ResponseBody组成,等号右边两位同志简单介绍两句,就明白我们@RestController的意义了:
- @Controller 将当前修饰的类注入SpringBoot IOC容器,使得从该类所在的项目跑起来的过程中,这个类就被实例化。当然也有语义化的作用,即代表该类是充当Controller的作用
- @ResponseBody 它的作用简短截说就是指该类中所有的API接口返回的数据,甭管你对应的方法返回Map或是其他Object,它会以Json字符串的形式返回给客户端,本人尝试了一下,如果返回的是String类型,则仍然是String。
@RestController
@RequestMapping("test")
public class SampleController {
@GetMapping
public Map testGet() {
return new HashMap<String, String>(){{
put("name", "springboot");
}};
}
@GetMapping(path = "str")
public String testGetStr() {
return "OK";
}
}
链接:https://www.jianshu.com/p/6bbb5748ac83