Cookie(复数形态:Cookies)是某些网站为了辨别用户身份而储存在用户本地终端上的数据。在接口测试过程中,如果网站采取了 Cookie 认证的方式,那么发送的请求需要附带 Cookie,才会得到正常的响应的结果。接口自动化测试也是同理,需要在构造接口测试用例时加入 Cookie。
实战练习
对于要对 Cookie 进行验证的网站发起请求,如果在请求过程中没有传递 Cookie 数据,则会返回错误的响应结果。下面的实战以雪球为例。
没有 Cookie 数据的场景
下方示例对雪球的 url 发起一个 get 请求,在请求过程中没有添加 Cookie 数据。
- >>> import requests
- >>>
- >>> url="https://xueqiu.com/stock/search.json"
- >>> params={"code": "sogo", "size": "3", "page": "1"}
- >>> header={ "Accept": "application/json",
- ... "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) \
- AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36",
- ... }
- >>> r = requests.get(url, params=params, headers=header)
- >>> r.text
- '{"error_description":
- "遇到错误,请刷新页面或者重新登录帐号后再试",\
- "error_uri":"/stock/search.json",
- "error_code":"400016"}'
- >>>
-
由上面的例子可以看到,如果在请求过程中没有添加 Cookie 数据,结果报错,要求登录账号。
添加 Cookie 的场景
接下来,在请求过程中添加正确的 Cookie 信息,即可得到正常的响应信息。
同样访问雪球,通过关键字参数 cookies 传递正确的 Cookie 数据。
- >>> import requests
- >>>
- >>> url="https://xueqiu.com/stock/search.json"
- >>> params={"code": "sogo", "size": "3", "page": "1"}
- >>> header={ "Accept": "application/json",
- ... "User-Agent": "Mozilla/5.0 \
- (Macintosh; Intel Mac OS X 10_14_6)\
- AppleWebKit/537.36 (KHTML, like Gecko) \
- Chrome/77.0.3865.90 Safari/537.36",
- ... }
- >>> cookies={
- "xq_a_token":"...省略..."
- }
- >>> requests.get(url,
- params=params, headers=header, cookies=cookies).text
- '{"q":"sogo","page":1,"size":3,"stocks":
- [{"code":"SOGO","name":"搜狗",
- "enName":"","hasexist":"false","flag":null,
- "type":0,"stock_id":1029472,"ind_id":0,
- "nd_name":"通讯业务","ind_color":null,
- "_source":"sc_1:1:sogo"}]}'
-
在 Java 中,可以使用 cookie() 方法传入雪球所需要的 Cookie 数据信息。
- import static io.restassured.RestAssured.*;
-
- public class Requests {
- public static void main(String[] args) {
- given().
- params("code", "sogo", "size", 3, "page", 1).
- cookie("xq_a_token", "...省略...").
- when().
- get("https://xueqiu.com/stock/search.json").
- then().statusCode(200).log().all();
- }
- }