python接口自动化-------token、cookies的获取和传递

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 就可以了

在这里插入图片描述

  • 14
    点赞
  • 82
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值