背景批量生成账号,依次循环给每个帐号模拟真实注册场景,添加appname和deviceid,然后登录
批量生成账号,代码如下
import json
import requests
for j in range(1, 21):
body = []
#因为接口传数组,一次最多接受数组元素500个
for i in range(1, 501):
print(str(i)+"uuu"+str(j))
data = {}
data["account"]="mctester"+str(i)+"uuu"+str(j)
data["hospitalName"]="北京协和医院"
data["department"]='中医消化科'
data["role"]='医生'
data["type"]="USERNAME"
data["fullName"]="测试中"
data["password"]='test12345'
data["userId"]=0
data["title"]="主任医师"
body.append(data)
print(body)
url = "http://qa-uas-xxx.xxx.xxx"
r = requests.post(url, headers={"Content-Type": "application/json"}, data=json.dumps(body))
print(r.json())
打印response的各个属性
image.png
在HTTP响应头的Link中的属性参数,用来表示与另一个资源之间的类型关系
给每个帐号,添加appname和deviceid,模拟真实注册场景,然后登录
import requests
import uuid
import json
for i in range(1,6):
for j in range(1, 6):
deviceid = str(uuid.uuid1())
#上下文接口url
con_url = "http://qa-uas.xxx.xxxcontext"
#上下文接口body
con_body = {
"app":{
"name":"medclips_plus",
"version" : "0.0.1",
"hotfixVersion":"789"
},
"device":{
"deviceId":deviceid,
"name":"mikasa",
"systemName" :"ios",
"systemVersion":"13.0",
"model":"Samsung",
"localizedModel":"a1000"
}
}
#上下文接口header
headers = {
'x-User-Agent': 'medclips_plus/5.26.0 (iPhone10,3, iOS 13.3.1) net/WIFI channelId/1000',
'Content-Type': 'application/json',
'X-Trace-Id': 'testid'
}
context = requests.request("POST", con_url, headers=headers, data = json.dumps(con_body))
con_dic = json.loads(context.text)
#返回的data值token下个登录接口用
print(con_dic['data'])
#登录
login_url = "http://qa-uas.xxx.xxx/login"
header={}
header['X-User-Token']=con_dic['data']
header['x-User-Agent']='medclips_plus/5.26.0 (iPhone10,3, iOS 13.3.1) net/WIFI channelId/1000'
header['X-Security-Id']= deviceid
header['Content-Type']='application/json'
login_body = {
'account':"mctester"+str(i)+"uuu"+str(j),
'password':'test12345'
}
response = requests.request("POST", login_url, headers=header, data = login_body)
print(response.text)
注意一个地方是,requests.request传参headers后面的值必须是字典格式,实验了下headers传json格式,报错AttributeError: 'str' object has no attribute 'items'
image.png
python相比java报错信息不是很直观,比如上面哪个字段格式错误,提示需要的格式是什么就好了,还绕个弯说传的格式没有预期格式的属性,得倒推这属性是啥数据类型所属的属性,那假如多个数据类型都有这个属性,那还不得一个个找了
python相比java特别灵活,它不需要调更多方法,不同类型变量可以传参给另一个变量也太好用了,不用太多的格式限制、格式转换
注意另一个地方是,requests.request的data参数,必须传json,否则请求参数错误返回400
con_body = {
"app":{
"name":"medclips_plus",
"version" : "0.0.1",
"hotfixVersion":"789"
},
"device":{
"deviceId":str(uuid.uuid1()),
"name":"mikasa",
"systemName" :"ios",
"systemVersion":"13.0",
"model":"Samsung",
"localizedModel":"a1000"
}
}
两种格式对比.png
另外一个小问题,python 2我们经常在文件头声明编码格式utf8,或者数据输出时编码格式设置utf8,python 3默认编码格式utf8,不需要声明和设置
image.png
直接用response.text就可以了~
当然如果需要非utf8的格式,还要把默认utf8格式再做相应转换。