Posted in Python onFebruary 12, 2022
接口测试返回数据为字典取值
接口测试通常需要校验返回数据跟预期结果是否一致,这个时候如果返回数据为字典,那么我们要拿到我们想要的key对应的values时,需巧妙的运用dict.keys()、dict.values()和for循环,以及列表相关知识点。
实例
这是我调接口返回的数据,该数据为dict类型,我的目标是要拿到account。
#接口返回的数据:
api_result = {'code': '000001',
'dataMap': {'data':
{'amount': 0, 'billingWeight': 0, 'quantity': 0}},
'failureString': '', 'failures': [],
'flag': 'success', 'hasError': False, 'message': '请求成功'}
方法
#方法1:
print("这是方法1")
for i in api_result.keys():
if i == 'dataMap':
print(api_result[i]['data']['amount'])
#方法2:
print("这是方法2")
getkey = api_result.get('dataMap')
# print(getkey)
cc =list(getkey.values())[0]
print(cc['amount'])
#方法3:
print("这是方法3")
print(api_result['dataMap']['data']['amount'])
运行结果
本次介绍了三个方法,一个循环,一个利用keys()和values(),另外一个直接嵌套取key对应的值。当然大家可以看出来,最后一种方法是最快最简单的。
python接口测试--sign签名
最近测试的项目由于需要给第三方调用,所以增加了安全性的认证,所有的接口调用都需要签名进行验签,
于是研究了一下使用python按照接口签名规范生成sign值。
接口签名规范
1、请求参数中的 sign 参数和为空的参数去除后,剩余的多个键值对,将键按照字典序排序,
并以key1=value1&key2=value2的格式拼成一个字符串
2、拼接的字符串需要URLEncode
3、将开发者的key拼接在第一步中排序后的字符串后面得到待签名字符串
4、使用md5算法加密待加密字符串并转为大写即为sign
实现代码
下面为实现的 代码片。
import time
import requests
import json
import urllib,hashlib
url = "http://www.xxx.xx"
#获取当前的时间戳
stamp = time.time()
print(stamp)
#转换为int类型的13位时间戳
timestam = int(round(stamp*1000))
print(timestam)
time_new = str(timestam)
print(type(time_new))
data ={
'appId':'3301820001',
"outTradeNo":"20201026001",
"amount":"100",
"body":"test",
"timestamp":time_new,
"notifyUrl":"http://localhost:8080/notify",
}
#将键按照字典序排序
data_order = sorted(data.items(),key=lambda x:x[0],reverse=False)
#将列表转化为字典
data_new = dict(data_order)
print(data_new)
#将key=value键值对进行url编码
datanew = urllib.parse.urlencode(data_new)
datadic = datanew + "&key=BF1BDE5A649724056F904A9335B1C1C7455655"
print(datadic)
#创建md5对象
m = hashlib.md5()
m= hashlib.md5(datadic.encode())
data_md5 = m.hexdigest()
#将小写字母切换为大写字母
sign=data_md5.upper()
print(sign)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。
python接口测试返回数据为字典取值方式
- Author -
全栈测试开发日记- Original Sources -
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@