python接口登陆超时

Python013

python接口登陆超时,第1张

python接口登陆超时解决方法如下:

1、利用python实现接口登陆超时,可以利用python实现接口调用,读取登陆信息,实现超时时间设置,当超时时间到达时,重新调用接口登陆。

2、利用python实现定时任务,可以利用python实现定时任务,定时调用接口,检查登陆信息,如果登陆信息超时,则重新登陆。

3、利用python实现主动超时检测,可以利用python实现客户端轮询,定时调用接口,检查登陆信息,如果登陆信息超时,则重新登陆。

Python是一种强大而完全可扩展的编程语言,可以用来开发大型且复杂的应用程序。Python提供了一系列接口,这些接口可以帮助开发者编写高效和可维护的代码。

前言

有些登录不是用cookie来验证的,是用token参数来判断是否登录。

token传参有两种一种是放在请求头里,本质上是跟cookie是一样的,只是换个单词而已;另外一种是在url请求参数里,这种更直观。

一、登录返回token

1.如下图的这个登录,无cookies

2.但是登录成功后有返回token

二、请求头带token

1.登录成功后继续操作其它页面,发现post请求的请求头,都会带token参数

2.这种请求其实比cookie更简单,直接把登录后的token放到头部就行

三、token关联

1.用脚本实现登录,获取token参数,获取后传参到请求头就可以了

2.如果登录有验证码,前面的脚本登录步骤就省略了,自己手动登录后获取token

import requests

header = { # 登录抓包获取的头部

"User-Agent": "Mozilla/5.0 (Windows NT 10.0WOW64rv:44.0) Gecko/20100101 Firefox/44.0",

"Accept": " / ",

"Accept-Language": "zh-CN,zhq=0.8,en-USq=0.5,enq=0.3",

"Accept-Encoding": "gzip, deflate",

"Content-Type": "application/x-www-form-urlencodedcharset=UTF-8",

"X-Requested-With": "XMLHttpRequest",

"Content-Length": "423",

"Connection": "keep-alive"

}

body = {"key1": "value1",

"key2": "value2"} # 这里账号密码就是抓包的数据

s = requests.session()

login_url = " http://xxx.login " # 自己找带token网址

login_ret = s.post(login_url, headers=header, data=body)

token = login_ret.json()["token"]

post_url = " http://xxx "

header["token"] = token

header["Content-Length"]="9"

body1 = {

"key": "value"

}

post_ret = s.post(post_url, headers=header, data=body1)

print post_ret.content

Python使用session接口时,如果出现登录超时的情况,可能是因为session过期了,需要重新设置session。可以尝试在代码中加入以下代码:```python# 设置session过期时间session.set_expiry(60 * 60 * 24) # 过期时间为24小时```