token是登录后产生的用户唯一标识 几乎所有的接口都需要token 才能进行访问
那么我就说一下关于token的处理
首先定义一个登录的请求方法
import requests
def login():
url = "http://test.xxxxxxx.com/api/common/login/login"
data = {
"phone":"1772xxxxxxx,
"password":123456
}
h = {
"User-Agent": "Android/H60-L01/8.1.0/"
}
res = requests.post(url, data=data, headers=h)
print(res.json())
login()
来看一下返回数据
返回数据就展示部分好了
{'status': 1, 'msg': '登录成功', 'data': {'id': 6335, 'nickname': 'mimi', 'phone': '1772xxxxxx', 'token': '3143de184efaa49581cd1966ed2ef1a1',
可以看出返回的数据是字典格式 而token是在data里 所以可以用字典取值的方式语提取token
提取token并将其返回
return ( res.json()['data']['token'])
然后将其传到下一个请求的headers里
def get():
print({'token':login()})
url = 'http://test.xxxxxxxxx.com/api/common/user/sign'
h = {
"User-Agent": "Android/H60-L01/8.1.0/",
'token':login()
}
res = requests.post(url,headers=h)
print(res.text)
这样就可以了
cookies的获取和传递
在登录接口 中用print(r.cookies)来打印cookies 看看 是否可以获取到
import requests
def login():
data = {
"phone":189xxxxxxxxxx,
"password":123456
}
headers = {
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36",
"Content-Type":"application/x-www-form-urlencoded; charset=UTF-8",
"Referer":"https://test.xxxxxxx.com/index/index/login/login.html"
}
r = requests.post(
url='https://test.xxxxxxxx.com/index/index/login/login',
data=data,
headers=headers)
print( r.cookies)
成功打印出Cookies 值
然后用return返回
return r.cookies
在下一个请求中 同token 类似 拼接到headers 就可以了