restful是客户端映射到服务器资源的一种架构设计,一种优雅的URL风格。
什么是优雅的URL风格?
万维网发明的时候,定义http协议比较随意,如http://www.xx.com,作者曾说过这两个斜杠是为了好看而设计的,所以从这句话可以看出当初设计http的时候根本就没有想太多,没有考虑后续使用的人没有一个规范,这导致后面每个人去设计这个URL都一套自己的命名风格,就导致非常的混乱。
比如根据id查询一个用户,可能有以下几种风格:
user/getuser.do?id=1
user.do?action=getUser&id=1
user.do?action=a&id=xx (action用a b c代替真实意图单词)
user/chaxunyonghu?id=1 (用拼音)
user/CXYH?id=1 (用拼音缩写)
user/xx_cxyh?id=1
user/a.do?action=b?c=xx
估计定义http协议的作者看到这一混乱局面,应该会感到暴躁,因为他觉得设计http的初衷不是给大家这样用的。因此后来Roy Filding博士在2000年他的博士论文中提出来一种软件架构风格(Representational State Transfer,简称REST,即表述性状态传递),它是一种针对网络应用的设计和开发方式,可以降低开发的复杂性,提高系统的可伸缩性。
rest不仅仅适用于web架构,而是适用于任何软件架构,软件架构的中心思想就是客户端映射到服务器资源的一种架构设计,到了web架构这里,我们就利用URL就能体现这个中心思想。
所以说白了我们可以这样狭义地去理解:一种相较于之前URL所产生的一种更优雅的URL风格。
举例说明:
如果是原来的架构风格,需要发送四个请求,分别是:
查询用户:http://localhost:8080/app/user.do?action=getUser&id=xxx GET
增加用户:http://localhost:8080/app/user_do POST
修改用户:http://localhost:8080/app/xiugaiuser.do POST
删除用户:http://localhost:8080/app/delete.do?id=1 GET/POST
按照此方式发送请求的时候比较麻烦,需要定义多种请求,而在HTTP协议中,有不同的发送请求的方式,分别是GET、POST、PUT、DELETE等,我们如果能让不同的请求方式表示不同的请求类型就可以简化我们的查询,改成名词。
之前一般用动词表示请求目的,现在用名词来体现资源更好,如下:
查询用户:http://localhost:8080/xxx/user/1 GET
查询多个用户:http://localhost:8080/xxx/users GET
增加用户:http://localhost:8080/xxx/user POST
修改用户:http://localhost:8080/xxx/user/1 PUT
删除用户:http://localhost:8080/xxx/user/1 DELETE
综上:
看Url就知道要什么
看http method就知道干什么
看http status code就知道结果如何