日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python批量请求url_python批量请求注册接口爬虫相关问题记录

發(fā)布時間:2024/1/8 python 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python批量请求url_python批量请求注册接口爬虫相关问题记录 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

背景批量生成賬號,依次循環(huán)給每個帳號模擬真實注冊場景,添加appname和deviceid,然后登錄

批量生成賬號,代碼如下

import json

import requests

for j in range(1, 21):

body = []

#因為接口傳數(shù)組,一次最多接受數(shù)組元素500個

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"]="測試中"

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的各個屬性

image.png

在HTTP響應(yīng)頭的Link中的屬性參數(shù),用來表示與另一個資源之間的類型關(guān)系

給每個帳號,添加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報錯信息不是很直觀,比如上面哪個字段格式錯誤,提示需要的格式是什么就好了,還繞個彎說傳的格式?jīng)]有預(yù)期格式的屬性,得倒推這屬性是啥數(shù)據(jù)類型所屬的屬性,那假如多個數(shù)據(jù)類型都有這個屬性,那還不得一個個找了

python相比java特別靈活,它不需要調(diào)更多方法,不同類型變量可以傳參給另一個變量也太好用了,不用太多的格式限制、格式轉(zhuǎn)換

注意另一個地方是,requests.request的data參數(shù),必須傳json,否則請求參數(shù)錯誤返回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我們經(jīng)常在文件頭聲明編碼格式utf8,或者數(shù)據(jù)輸出時編碼格式設(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批量请求注册接口爬虫相关问题记录的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。