RESTful学习及应用
原文转自前端路上,转载请注明出处:http://refined-x.com/2017/09/22/RESTful学习及应用/
RESTful是什么
RESTful是一种API架构,符合REST设计原则的API都可以被称为RESTful,REST的全称是Representational State Transfer。
REST的核心原则是后端将资源发布为URI,前端通过URI访问资源,并通过HTTP动词表示要对资源进行的操作,典型的RESTful API长这样:
POST /artical //增加一篇文章
DELETE /artical/1 //删除id为1的文章
PUT /artical/1 //修改id为1的文章
GET /articals/1 //查询id为1的文章
这里需要明确一个概念:资源,后端提供的所有内容都可以被定义为资源,前端用户的一切行为,本质都是与一系列后端资源互动的结果。从这个角度来讲,前端的意义就是连接用户与资源,使用户能以最简单的方式调度后端资源,并将调度结果以用户最容易接受的方式呈现出来。
为什么使用RESTful
前后端分离的本质是前后端以API为界限进行开发解耦,所以前后端分离的副产品是大量的API,采用RESTful架构可以让API的表现力更强,更易于被理解;对于接口开发来说,RESTful风格也更易于扩展,这对于大型项目非常重要。
RESTful是无状态的,因此无论前端是什么设备,前端是什么状态,都可以无差别的请求资源,有利于后端实现分布式。
RESTful允许前端索取指定格式的信息,因此可以实现一套统一的API服务于不同的前端设备。
如何构建RESTful API
一、每个网址代表一种资源,网址中只能有名词
网址仅用来表示资源的名称,而不包括操作,因此只能由名词组成;但有些资源可能自带操作属性,比如转账,这时候我们应该将转账看成一种服务(名词),将转账的其他信息作为参数传递
二、对于资源的操作类型由HTTP动词表示
常用的四种HTTP动词以及对应的SQL操作。
GET(SELECT):从服务器取出资源(一项或多项)。
POST(CREATE):在服务器新建一个资源。
PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)
DELETE(DELETE):从服务器删除资源。
三、统一的返回结果
针对不同操作,服务器向用户返回的结果应该符合以下规范。
GET /collection:返回资源对象的列表(数组)
GET /collection/resource:返回单个资源对象
POST /collection:返回新生成的资源对象
PUT /collection/resource:返回完整的资源对象
PATCH /collection/resource:返回完整的资源对象
DELETE /collection/resource:返回一个空文档
四、返回正确的状态码
常用状态码
200 :服务器成功返回用户请求的数据
400 :用户发出的请求有错误
401 :表示用户没有权限
403 : 表示用户得到授权(与401错误相对),但访问被禁止的
404 :用户发出的请求针对的是不存在的记录
500 :服务器发生错误,用户无法判断发出的请求是否成功
五、允许通过HTTP内容协商
客户端可以通过Accept头请求一种特定格式的表述,服务端则通过Content-Type告诉客户端资源的表述形式。若服务器不支持,它应该返回一个HTTP 406响应,表示拒绝处理该请求。
通常项目中最常用的还是直接预定为JSON格式。
web端的应用
目前最流行的web端AJAX类库当属axios,axios与RESTful完美兼容,主要体现在以下几个方面。
axios将HTTP动词直接封装为方法,正好对应RESTful的API风格,在RESTful架构中使用起来非常方便
axios.post(`/artical`, params)
axios.delete(`/artical/1`, params)
axios.put(`/artical/1`, params)
axios.get(`/artical/1`, params)
而且axios的返回数据包括响应正文和状态码等信息,配合拦截器很容易实现对RESTful API错误码的统一处理。
//错误处理
axios.interceptors.response.use(function(response) {
return response;
}, function(error) {
if (error.response) {
switch (error.response.status) {
case 400: break;
case 401: break;
case 403: break;
...
}
}
});
更多axios内容参考这里。
最后
其实RESTful的绝大多数内容都是规范推荐的做法,没有什么新东西,只不过前几年后端MVC盛行的时期,没有这么重的API开发需求,在这方面就一切从简了,近来赶上前后端分离的东风,API设计又被大家重视起来了,重回规范的RESTful相当于让大家见识了一下当年规范制定者们的远见卓识,就像小时候不听话的孩子在长大的某一天里突然想起来长辈曾经的教诲一样。
RESTful学习及应用的更多相关文章
- RESTful学习记录
1.1 什么是RESTful RESTful架构,就是目前最流行的一种互联网软件架构.它结构清晰.符合标准.易于理解.扩展方便,所以正得到越来越多网站的采用. RESTful(即Representat ...
- RESTful学习笔记
作为一名只有几个月IT自学经历的人,在接受新知识的时候总是想找到浅显易懂的方式去理解,但往往却很难找到相关的文章,大部分都是针对具有一定经验的开发人员,因此在看了很多相关的文章才对RESTful架构有 ...
- RESTful学习文档
视频讲解 http://www.tudou.com/programs/view/PaVOGeK_BOY/ 文档说明 http://www.csdn.net/article/2013-06-13/281 ...
- 慕课网Java高并发秒杀学习
课程地址:http://www.imooc.com/learn/587 一个很好:spring,springMVC,mybatis,bootstrap,jQuery,mysql,Restful学习案例 ...
- RESTful接口设计原则/最佳实践(学习笔记)
RESTful接口设计原则/最佳实践(学习笔记) 原文地址:http://www.vinaysahni.com/best-practices-for-a-pragmatic-restful-api 1 ...
- Spring MVC 学习总结(九)——Spring MVC实现RESTful与JSON(Spring MVC为前端提供服务)
很多时候前端都需要调用后台服务实现交互功能,常见的数据交换格式多是JSON或XML,这里主要讲解Spring MVC为前端提供JSON格式的数据并实现与前台交互.RESTful则是一种软件架构风格.设 ...
- Java Restful Web Service 学习指南
Restful是一种架构style,目前常说的有restful web service, resultful http.现在热搜榜的微服务,大多数会采用Restful方式. JAX-RS 作为一个Re ...
- DjangoRestFramework 学习之restful规范 APIview 解析器组件 Postman等
DjangoRestFramework学习一之restful规范.APIview.解析器组件.Postman等 本节目录 一 预备知识 二 restful规范 三 DRF的APIView和解析器组件 ...
- Flask 学习篇一: 搭建Python虚拟环境,安装flask,并设计RESTful API。
前些日子,老师给我看了这本书,于是便开始了Flask的学习 GitHub上的大神,于是我也在GitHub上建了一个Flask的项目. 有兴趣可以看看: https://github.com/Silen ...
随机推荐
- 章节九、5-IE Driver
一.下载IE浏览器驱动,然后解压到存放谷歌和火狐驱动的相同路径中(请观看前面的章节) 下载地址一:http://selenium-release.storage.googleapis.com/inde ...
- SpringBoot2.0之七 实现页面和后台代码的热部署
开发过程中我可能经常会因为修改一点点代码就需要重启项目而烦恼,这样不仅很繁琐,还会因为不断重启浪费大量的时间,无法提高工作效率.可是现在SpringBoot为我们提供了非常简单的方式让我们实现热部署. ...
- 基于Kubernetes 构建.NET Core 的技术体系
很多公司技术支持岗位的工作,如配置域名,部署环境,修改复位配置,服务重启,扩容缩容,梳理和完善监控,根据开发的需要查找日志等工作,需要和开发进行大量的沟通,如什么是外网域名,什么是内网域名.A nam ...
- brew 安装指定版本命令行工具 tmux 多版本实现
Homebrew 是 macOS 命令安装工具,其核心库里的命令行在 github homebrew-core 仓库上维护. 核心库命令大概有 5000 条左右,大部分的命令行工具只保留了最新版本的 ...
- Java核心技术第八章——泛型程序设计(1)
1.泛型程序设计 泛型程序设计意味着编写的代码可以被很多不同类型的对象所重用.例如:不希望为了聚集String和Integer对象分别设计不同的类.(个人觉得此处说的聚集译为:创建一个对象,属性可以为 ...
- 数组属性的习题、Arrays工具、二维数组
一.数组的练习 1.声明一个char类型的数组, 从键盘录入6个字符: [1]遍历输出 [2]排序 [3]把char数组转化成一个逆序的数组. import java.util.Scanner; pu ...
- Django rest framework源码分析(1)----认证
目录 Django rest framework(1)----认证 Django rest framework(2)----权限 Django rest framework(3)----节流 Djan ...
- qml demo分析(customgeometry-贝塞尔曲线)
一.效果展示 本篇文章还是带来一个简单的qt示例分析,且看图1效果. 图1 贝塞尔曲线 二.源码分析 该示例代码所在目录quick\scenegraph\customgeometry,感兴趣的同学可以 ...
- TabLayoutBottomDemo【TabLayout实现底部选项卡】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 使用TabLayout实现底部选项卡切换功能. 效果图 代码分析 1.演示固定模式的展现 2.演示自定义布局的实现 使用步骤 一.项 ...
- Spring入门(二):自动化装配bean
Spring从两个角度来实现自动化装配: 组件扫描(component scanning):Spring会自动发现应用上下文中需要创建的bean. 自动装配(autowiring):Spring会自动 ...