Http 协议。
目前大部分移动端与服务端之间都是通过 HTTP 协议进行数据交互的。
4 种操作方法。
Http 的 Get、Post、Put、Delete 方法
Http 协议是一个应用层的协议,是一种网络交互需要遵守的一种协议规范。
Http 协议组成
Http 传输
Http URL 格式:http://host:port] path][
向服务器发出请求时,它向服务器传递了一个数据块,也就是请求信息,由 3 部分组成:
请求方法、URI 协议、版本;
请求头(Request Header);
请求参数。
如下截图所示:
其中:
URI:纯粹是一个符号结构,用于指定构成 Web 资源的字符串的各个不同部分。
URL:是一种特殊类型的 URI,它包含了用于查找某个资源的足够的信息。
Cookies:可以理解为客户端保存信息的一种机制,用于记录一些信息,也是实现 session 的一种方式。
Session:可以理解为在服务端保存一个数据结构,可以用于某些状态或属性。
接收到服务器响应信息也由 3 个部分构成,分别是:
其中,常见状态代码、状态描述:
200 OK:客户端请求成功。
400 Bad Request:客户端请求有语法错误,不能被服务器所理解。
403 Forbidden:服务器收到请求,但是拒绝提供服务。
404 Not Found:请求资源不存在。
500 Internal Server Error:服务器发生不可预期的错误。
1、连接:建立一个 socket 连接;
因为 socket 是通过 ip 和端口建立的,在这之前还会进行 DNS 解析将域名解析成对应的 ID 地址。
2、请求:连接成功后,向服务器发送 GET/POST 请求。
GET, 一般用于获取信息。请求数据会放置在 HTTP 协议头中,以 ? 分割 URL 和传输数据,多个数据以 & 相连。参数受限于 URL 长度,不同浏览器有不同的长度限制。
POST,一般用于向服务器提交数据,以 FORM 表单的形式。没有大小限制。
GET 参数通过 URL 传递,POST 放在 Request body 中。
3、响应:服务器收到这个请求,进行处理,再将响应数据传送回客户端。
4、关闭连接:响应结束后,客户端与服务器断开连接,以保证其它客户端与服务器建立连接。
Tips:99% 的人都理解错了 HTTP 中 GET 与 POST 的区别
全业务逻辑覆盖
响应结构
数据格式
数据正确性
依据数据来源:查数据库或服务端和接口返回值做比较
例:参数缺失服务端是否正常解析
例:服务端只接收 int 类型,传递了 String 类型
例:存储长度 10 位,传参大于 10 位,接口是否处理
例:type=1 查询北京、Type=2 查询天津
例:交互过程中服务端需要验证 head 中的数据、或者是否有加密协议
Fiddeler、Charles、Postman、 Json-handle 插件、 Json.cn、 ......
其中 Postman 类似于我司的 mock 工具。
Soapui、Robot framework、Httpclient、Rest assured、Swagger......
推荐使用 Rest assured 框架进行接口测试,语法足够简单,编写测试用例速度快,而且还 供了相应的断言机制、json 验证以及封装了相关 jsonpath、xmlpath,使接口测试更加方便快捷。
<dependency>
<groupId>io.rest-assured</groupId>
<artifactId>rest-assured</artifactId>
<version>3.0.2</version>
</dependency>
<dependency>
<groupId>io.rest-assured</groupId>
<artifactId>json-path</artifactId>
<version>3.0.2</version>
</dependency>
<dependency>
<groupId>io.rest-assured</groupId>
<artifactId>xml-path</artifactId>
<version>3.0.1</version>
</dependency>
Get: 发起请求 + 基本解析;
Post:发起请求 + 基本解析;
基于 Excel 的数据驱动:Excel 读取 + 执行结果写入。
rest-assured 使用文档参考文章:rest-assured 中文文档