python批量请求url_python批量请求注册接口爬虫相关问题记录
背景批量生成賬號(hào),依次循環(huán)給每個(gè)帳號(hào)模擬真實(shí)注冊(cè)場(chǎng)景,添加appname和deviceid,然后登錄
批量生成賬號(hào),代碼如下
import json
import requests
for j in range(1, 21):
body = []
#因?yàn)榻涌趥鲾?shù)組,一次最多接受數(shù)組元素500個(gè)
for i in range(1, 501):
print(str(i)+"uuu"+str(j))
data = {}
data["account"]="mctester"+str(i)+"uuu"+str(j)
data["hospitalName"]="北京協(xié)和醫(yī)院"
data["department"]='中醫(yī)消化科'
data["role"]='醫(yī)生'
data["type"]="USERNAME"
data["fullName"]="測(cè)試中"
data["password"]='test12345'
data["userId"]=0
data["title"]="主任醫(yī)師"
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的各個(gè)屬性
image.png
在HTTP響應(yīng)頭的Link中的屬性參數(shù),用來表示與另一個(gè)資源之間的類型關(guān)系
給每個(gè)帳號(hào),添加appname和deviceid,模擬真實(shí)注冊(cè)場(chǎng)景,然后登錄
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下個(gè)登錄接口用
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)
注意一個(gè)地方是,requests.request傳參headers后面的值必須是字典格式,實(shí)驗(yàn)了下headers傳json格式,報(bào)錯(cuò)AttributeError: 'str' object has no attribute 'items'
image.png
python相比java報(bào)錯(cuò)信息不是很直觀,比如上面哪個(gè)字段格式錯(cuò)誤,提示需要的格式是什么就好了,還繞個(gè)彎說傳的格式?jīng)]有預(yù)期格式的屬性,得倒推這屬性是啥數(shù)據(jù)類型所屬的屬性,那假如多個(gè)數(shù)據(jù)類型都有這個(gè)屬性,那還不得一個(gè)個(gè)找了
python相比java特別靈活,它不需要調(diào)更多方法,不同類型變量可以傳參給另一個(gè)變量也太好用了,不用太多的格式限制、格式轉(zhuǎn)換
注意另一個(gè)地方是,requests.request的data參數(shù),必須傳json,否則請(qǐng)求參數(shù)錯(cuò)誤返回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"
}
}
兩種格式對(duì)比.png
另外一個(gè)小問題,python 2我們經(jīng)常在文件頭聲明編碼格式utf8,或者數(shù)據(jù)輸出時(shí)編碼格式設(shè)置utf8,python 3默認(rèn)編碼格式utf8,不需要聲明和設(shè)置
image.png
直接用response.text就可以了~
當(dāng)然如果需要非utf8的格式,還要把默認(rèn)utf8格式再做相應(yīng)轉(zhuǎn)換。
總結(jié)
以上是生活随笔為你收集整理的python批量请求url_python批量请求注册接口爬虫相关问题记录的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SAP中国客户名单
- 下一篇: websocket python爬虫_p