request库:python来发送http请求的。(用代码来带起postman的操作)
例如:微博开放平台
unittest:也做单元测试---->断言
requests安装,在终端输入
pip install requests
import requests
#request操作请求头以及携带参数,获取响应的jsons数据
#准备请求头的数据
deader = {
"Authorization": "Bearer 029981f2-ec96-4456-a0de-ee169a77e520",
"Content-Type": "application/json "
}
url = "http://localhost:8080/api/sys/user"
data = {
"page": 1,
"size": 10
}
# 发起请求,headers是请求头的数据,params是请求所携带的参数
res = requests.get(url=url, headers=deader, params=data)
print(res)
data = res.json()
print(data)
requests模块处理session和cookie
# 登录状态保持
url = "http://yun.zenm.vip/iot/account/login/"
# 生成状态保持的session对象
session = requests.Session()
data = {
'username': 'peter',
'password': 'admin',
}
# 使用session的时候,请求的参数要转化为json格式
import json
json_data = json.dumps(data)
header = {
"Content-Type": "application/json "
}
res = session.post(url=url, data=json_data, headers=header)
print(res)
print(res.json())
# 后续的请求继续在session对象里发起即可
url_mine = 'http://yun.zenm.vip/iot/account/get/companys/'
res5 = session.get(url=url_mine)
print(res5.json())
状态保持的方式:
方式一:
使用的cookies+session
是将登录的信息放在session里,再把session放在cookies里,每次请求的时候浏览器都会自动带上cookies里的信息,达到登录状态保持的效果。
所有的用户信息放在session,session在服务器上,所以每次拿到session都会来服务器做对比
方式二:
基于token的登录状态保持,token是放在请求头
请求处理的时候从请求头里拿出来token,跟这个token进行对比。
- 不会占用服务器的资源来储存用户的的登录信息。
Token
#查全部员工
def fun2():
URL = "http://localhost:8080/api/sys/login"
data = {
"mobile": "13800000002", "password": "123456"
}
json_data = json.dumps(data)
deader = {
"Content-Type": "application/json"
}
res = requests.post(url=URL, data=json_data, headers=deader)
res_data = res.json()
print(res_data)
token = res_data["data"]
print(token)
new_token = "Bearer " + token
new_deader = {
"Authorization": new_token,
"Content-Type": "application/json"
}
url = "http://localhost:8080/api/sys/user"
data = {
"page": 1,
"size": 10
}
# 发起请求,headers是请求头的数据,params是请求所携带的参数。
res1 = requests.get(url=url, headers=new_deader, params=data)
print(res1)
res_data = res1.json()
print(res_data)
if __name__ == '__main__':
fun2()