一、requests 模块基本使用
1、准备接口的URL、请求参数、请求头
# 1. 构造注册、登录、充值请求的url
register_url = "注册url"
login_url = "登录url"
recharge_url = "充值url"
# 2. 创建请求参数
register_params = {
"mobilephone": "18244446666",
"pwd": "123456",
"regname": "yuxing"
}
login_params = {
"mobilephone": "18244446667",
"pwd": "123456",
}
recharge_params = {
"mobilephone": "18244446667",
"amount": "500000",
}
# 可以添加请求头,反爬虫措施,所以有的需要自己添加合法的请求, 但是多数情况下, 不需要修改
headers = {
"User-Agent": "Mozilla/5.0 shengruhuakai"
}
3、向服务器发送请求
get 请求:使用 requests 库中 get 方法
# get请求:使用 requests 库中 get 方法
# 如果给 params (派瑞斯)传参, 那么是以查询字符串参数的形式来传的--在url后传参
res = requests.get(register_url, params=register_params)
# 如果需要请求头则加上 headers 请求头参数
res1 = requests.get(register_url, params=register_params, headers=headers)
# 返回的 res 是一个Response的对象, 就可以把它当作是一个响应报文
# 可以从返回的对象中获取需要的数据----根据不同系统,获取字段也不同
# 获取响应状态码
print(res.status_code)
# 获取响应报文
print(res.text)
# 将响应报文转化为Python中的字典数据类型
print(res.json())
# 获取cookie
print(res.cookies)
post请求:使用 requests 库中 post 方法
# post请求:使用 requests 库中 post 方法
# 一般情况下 post 请求不会以 params 来传参
# 如果给 params 传参, 那么是以查询字符串参数的形式来传的--在url后传参不安全
res3 = requests.post(register_url, params=register_params, headers=headers)
# 返回的是一个 Response (瑞思帮死)的对象, 就可以把它当作是一个响应报文
# 从响应报文中获取需要参数
print(res3.status_code)
如果给 data 传参, 那么会以 x-www-form-urlencoded 的形式来传参
如果给 json 传参, 那么会以 json 格式的字符串形式来传参
# 如果给 data 传参, 那么会以 x-www-form-urlencoded 的形式来传参
res4 = requests.post(register_url, data=register_params, headers=headers)
# 返回的是一个Response的对象, 就可以把它当作是一个响应报文
# print(res4.status_code)
# 如果给 json 传参, 那么会以 json 格式的字符串形式来传参
# 这里的params既可以是字典, 也可以是json格式的字符串----但是不以字符串来传,字典不易出错
# 所有的参数, 都转化为字典之后来传递
res5 = requests.post(register_url, json=register_params, headers=headers)
# 返回的是一个Response的对象, 就可以把它当作是一个响应报文
print(res5.status_code)
如果需要上个接口的 cookie
第一种方法:在登录后取出 coolie 以参数的形式传给 充值接口,不方便一般不使用
# 先登录
login_res = requests.post(login_url, data=login_params, headers=headers)
# cookie = login_res.cookies['JSESSIONID'] # 不能单独取出字符串传递
print(login_res.status_code)
cookie = login_res.cookies # 只能传递cookies对象
# 充值 ---- cookies 以参数传递
recharge_res = requests.post(recharge_url, data=recharge_params, headers=headers, cookies=cookie)
print(recharge_res.status_code)
第二种方法:使用 requests (瑞考斯特)中的 Session(赛神)创建会话,之后使用 Session 会话发送请求
# 创建 Session 会话对象, 相当于Jmeter当中的Cookie管理器
one_session = requests.Session()
# 先登录,使用会话发送请求
login_res = one_session.post(login_url, data=login_params, headers=headers)
# 充值
recharge_res = one_session.post(recharge_url, data=recharge_params, headers=headers)
# 关闭会话,close(科楼司)
# 关闭之后, 依然可以发起请求
# 关闭会话只不过是释放资源
one_session.close()
二、封装 requests 模块
import requests import json from scripts.handle_log import do_log class HandleTheRequest: """ 封装请求接口类 """ def __init__(self): """ 创建会话对象,定义一个session的参数 """ self.one_session = requests.Session() def to_request(self, url, method, data=None, headers=None, is_json=False): """ 定义一个请求方法 :param url: 接口地址 :param method: 请求方法get、post :param data: 参数 :param headers: 请求头 :param is_json: 是否为json请求数据 :return: 请求结果 """ if isinstance(data, str): try: data = json.loads(data) except Exception as e: data = eval(data) do_log.error("数据转换器错误".format(e)) if method.lower() == "get": # 将输入的请求方法转化为大写/lower res = self.one_session.get(url, params=data) elif method.lower() == "post": if is_json: # 如果is_json为True,就以json格式的形式来传参 res = self.one_session.post(url, json=data, headers=headers) else: # 如果is_json为False,就以www-form的形式传参 res = self.one_session.post(url, data=data, headers=headers) else: res = None print("不支持[{}]这种方法传参".format(method)) do_log.error("发送的请求不是get/post,不支持的请求方式".format(method)) return res def close(self): """ 关闭session会话 :return: """ self.one_session.close() # do_register = HandleTheRequest() if __name__ == '__main__': # 1.构造前端的接口 register_url = "请求地址" # 2.构造请求参数,为字典烈性Params register_params = { "mobilephone": "13211110003", "pwd": "123456", "regname": "shouhu" } # 添加请求头 headers = { "User-Agent": "Mozilla/5.0 shouhu" } a1_request = HandleTheRequest() register_request = a1_request.to_request(url=register_url, method="post", data=register_params, headers=headers) # 传请求头 # register_request = a1_request.to_request(url=register_url, method="post", data=register_params) print(f"cookies值为:{register_request.cookies}") # 关闭会话 a1_request.close() # 如果以json格式传参需要设置为 True # initiate_request.to_request(method="post", url=recharge_url, data=recharge_params, is_json=True) pass
*******请大家尊重原创,如要转载,请注明出处:转载自:https://www.cnblogs.com/shouhu/ 谢谢!!*******