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

该博客介绍了如何使用Python批量生成账号并进行模拟注册,包括添加appname和deviceid,然后模拟登录的过程。通过requests库发送POST请求,处理HTTP响应,并强调了Python在处理请求参数和数据格式方面的灵活性。此外,还提到了Python3默认的UTF-8编码处理。
摘要由CSDN通过智能技术生成

背景批量生成账号,依次循环给每个帐号模拟真实注册场景,添加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的各个属性

d0d776131418

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'

d0d776131418

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"

}

}

d0d776131418

两种格式对比.png

另外一个小问题,python 2我们经常在文件头声明编码格式utf8,或者数据输出时编码格式设置utf8,python 3默认编码格式utf8,不需要声明和设置

d0d776131418

image.png

直接用response.text就可以了~

当然如果需要非utf8的格式,还要把默认utf8格式再做相应转换。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值