python接口自动化4-常用取token值方法
Posted 广深-小龙 --扬帆起航!
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python接口自动化4-常用取token值方法相关的知识,希望对你有一定的参考价值。
前言
在接口测试中我们经常是需要一个登陆token,或者获取其他用到的参数来关联下一个接口用到的参数。这里介绍一些本人常用的方法。
一、简介
不过在哪里我们也是能实现自动化api测试的,我们都知道token一般都会在这几个地方:
1.返回参数的token;
2.返回头部信息中;
3.上一个页面中;
二、取 token 常用方法
1.在返回参数中,如json:
R_json = { "code": 200, "message": "登录成功", "token": "ef135bce4284s45ab5967fdf22e81fa2" } print(R_json["token"])
2.在返回参数中还有,json嵌套list、json:
# 多层嵌套取token值 R_json = {"jjson": [ { "code": 200, "message": "账号或密码错误", "token": "" }, {"code": 200, "message": "登录成功", "token": "ef135bce4284s45ab5967fdf22e81fa2" } ]} print(R_json["jjson"][1]["token"])
3.在返回参数中,是html或者是raw文本显示的我们可以通过正则取到值:
常用的正则有以下三种:
①取中间:xxx(.+?)xxx
②取后面:xxx(.+?)$
③取前面:^(.+?)xxx
import requests import re # html 中常用到 re 取值 url = \'https://www.baidu.com\' s = requests.get(url) res = s.content.decode(\'utf-8\') token = re.findall(\'href=//(.+?) name\', res) # 取中间 print(token) # 取到的是 list print(token[0]) # 所以我们一般[0],取第一个即可。
4.在响应头部中
url = \'https://www.baidu.com/\' s = requests.get(url) print(s.headers) # 如果token在返回头部信息中我们可以这样获取 print(s.headers["Cache-Control"]) token = re.findall("no-cache, (.+?), ", s.headers["Cache-Control"]) print("token是:"+token[0])
看到了此,是不是觉得re正则还是很实用的呢?赶紧去随便请求个接口拿到一个你想要的值吧!!!
欢迎来QQ交流群:482713805
以上是关于python接口自动化4-常用取token值方法的主要内容,如果未能解决你的问题,请参考以下文章
python接口自动化34-json校验神器jsonschema
python接口自动化23-token参数关联登录(登录拉勾网)