RESTful+API开发与测试.ppt
文本预览下载声明
四、RESTful API 测试 1、编码测试 2、工具测试 四、RESTful API 测试 1、编码测试 a、java原生API 四、RESTful API 测试 1、编码测试 b、httpClient 四、RESTful API 测试 1、编码测试 c、python 四、RESTful API 测试 1、编码测试 d、jQuery 四、RESTful API 测试 2、工具测试 a、Fiddler 四、RESTful API 测试 2、工具测试 b、Jmeter RESTful API开发与测试 平台功能模块简介 一、RESTful 简述 二、RESTful API编写规范 三、RESTful API在SSM中的实现 四、RESTful API测试 一、RESTful简述 REST(英文:Representational State Transfer,简称REST)描述了一个架构样式的网络系统,比如 web 应用程序。 REST 指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是 RESTful;Web 应用程序最重要的 REST 原则是,客户端和服务器之间的交互在请求之间是无状态的;在服务器端,应用程序状态和功能可以分为各种资源。 二、 RESTful API编写规范 1、协议 API与用户的通信协议,总是使用HTTPs协议。 2、域名 应该尽量将API部署在专用域名之下: 如果确定API很简单,不会有进一步扩展,可以考虑放在主域名下: /api/ 二、 RESTful API编写规范 3、版本(Versioning) 应该将API的版本号放入URL: /v1/ 另一种做法是,将版本号放在HTTP头信息中,但不如放入URL方便和直观。 4、路径(Endpoint) 路径又称终点(endpoint),表示API的具体网址。在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表格名对应。一般来说,数据库中的表都是同种记录的集合(collection),所以API中的名词也应该使用复数。 二、 RESTful API编写规范 4、路径(Endpoint) 举例来说,有一个API提供动物园(zoo)的信息,还包括各种动物和雇员的信息,则它的路径应该设计成下面这样: /v1/zoos /v1/animals /v1/employees 二、 RESTful API编写规范 5、HTTP动词 对于资源的具体操作类型,由HTTP动词表示。 常用的HTTP动词有下面五个(括号里是对应的SQL命令): GET(SELECT):从服务器取出资源(一项或多项)。 POST(CREATE):在服务器新建一个资源。 PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)。 PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性)。 DELETE(DELETE):从服务器删除资源。 二、 RESTful API编写规范 5、HTTP动词 还有两个不常用的HTTP动词: HEAD:获取资源的元数据。 OPTIONS:获取信息,关于资源的哪些属性是客户端可以改变的。 二、 RESTful API编写规范 5、HTTP动词 下面是一些例子: GET /zoos:列出所有动物园 POST /zoos:新建一个动物园 GET /zoos/ID:获取某个指定动物园的信息 PUT /zoos/ID:更新某个指定动物园的信息(提供动物园的全部信息) PATCH /zoos/ID:更新某指定动物园的信息(提供动物园的部分信息) DELETE /zoos/ID:删除某个动物园 GET /zoos/ID/animals:列出某个指定动物园的所有动物 DELETE /zoos/ID/animals/ID:删除某个指定动物园的指定动物 二、 RESTful API编写规范 6、过滤信息(Filtering) 如果记录数量很多,服务器不可能都将它们返回给用户。API应该提供参数,过滤返回结果。 下面是一些常见的参数: ?limit=10:指定返回记录的数量 ?offset=10:指定返回记录的开始位置。 ?page=2per_page=100:指定第几页,以及每页的记录数。 ?sortby=nameorder=asc:指定返回结果按照哪个属性排序,以及排序顺序。 ?animal_type_id=1:指定筛选
显示全部