利用cookies进行登录并封装请求方法
2023-09-11 14:21:26 时间
之前写了一篇使用session跨请求保持会话的帖子,这次在它的基础上对请求方法简单封装一下,可以达到复用的效果
1.先定义登录方法
在登录方法中利用session跨请求保持会话,并返回session,login_ApprExclusive.py代码如下:
# coding:utf-8
import requests
class Login:
"""定义登录方法"""
@staticmethod
def test_login():
s = requests.session()
jar = requests.cookies.RequestsCookieJar() # 创建一个Cookie Jar对象
jar.set('49BAC005-7D5B-4231-8CEA-16939BEACD67', 'cktest001') # 向Cookie Jar对象中添加cookie值,这是登录的cookies
jar.set('JSESSIONID', 'ED2D58E3B438CC7597CB52CD31489914')
jar.set('JSESSIONIDSSO', 'D16E59009557B82F5D5885DC4DAA0179')
s.cookies.update(jar) # 把cookies追加到Session中
return s # 返回携带cookies的session
2.定义请求方法
把get和post请求方法进行封装,注意这里不是用requests来发送请求了,而是用上一步登录方法中返回的session来发送,这样就达到了跳过验证码登录的目的(使用登录后的session会话发送请求)
Run_Method.py的代码如下:
# coding:utf-8
import json
from case.login.login_ApprExclusive import Login
class RunMain:
def __init__(self):
self.s = Login() # 获取登录方法中的session
def send_post(self, url, header, data):
r = self.s.test_login().post(url=url, headers=header, data=data, verify=False) # 使用session发送请求
result = r.json()
return json.dumps(result, indent=2, sort_keys=False, ensure_ascii=False)
# return result
def send_get(self, url, header, data):
r = self.s.test_login().get(url=url, headers=header, params=data, verify=False)
result = r.json()
# print(type(result))
return json.dumps(result, indent=2, sort_keys=False, ensure_ascii=False)
# return result
def run_main(self, url, method, header=None, data=None):
r = None
if method == 'GET':
r = self.send_get(url, header, data)
else:
r = self.send_post(url, header, data)
return r
3.测试一个接口
测试代码如下:
# coding:utf-8
import unittest
from common_util.run_method import RunMain # 从之前封装的文件中,引入RunMain类
class ModuleList(unittest.TestCase):
def setUp(self):
self.run = RunMain()
self.url = 'http://localhost:8088/consult/saveConsult.do'
self.header = {
"Host": "localhost.:8088",
"Connection": "keep-alive",
"Content-Length": "89",
"Accept": "application/json, text/javascript, */*; q=0.01",
"Origin": "http://localhost.:8088",
"X-Requested-With": "XMLHttpRequest",
"User-Agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.75 Safari/537.36",
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
"Referer": "http://localhost.:8088/ApprExclusive/appr/enterprise/info/consult/toConsultEdit.do",
"Accept-Encoding": "gzip, deflate",
"Accept-Language": "zh-CN,zh;q=0.8"
}
def test01(self):
"""录入一条咨询"""
data = {
'clientCode': 'test',
'topic': 'topic',
'content': 'test',
'resrcType': '0'
}
r = self.run.run_main(self.url, 'GET', self.header, data)
print(r)
if __name__ == '__main__':
unittest.main()
ok,到此结束。
相关文章
- 第九节: 利用RemoteScheduler实现Sheduler的远程控制 第八节: Quartz.Net五大构件之SimpleThreadPool及其四种配置方案 第六节: 六类Calander处理六种不同的时间场景 第五节: Quartz.Net五大构件之Trigger的四大触发类 第三节: Quartz.Net五大构件之Scheduler(创建、封装、基本方法等)和Job(创建、关联
- koa 基础(二十四)封装 DB 库 --- 新增数据、更新数据、删除数据
- uni-app - 文字上下循环滚动翻滚,类似中奖名单与公告栏信息公示等等,自定义组件封装,支持 DIY(适用于新闻动态、公告上下滚动列表、上下循环滚动,无限上下自动滚动列表)兼容小程序/H5/App
- web自动化测试:Selenium+Python基础方法封装
- 微信小程序HTTP封装请求
- 第32节:Java中-构造函数,静态方法,继承,封装,多态,包
- java 方法作为参数封装在map
- 《像计算机科学家一样思考Python》——4.4 封装
- base.js,通用js方法,Js方法封装
- Python对于封装性的看法
- uniapp 工具类方法封装
- macOS SwiftUI 封装组件之 可选择可输入组合文本框NSComboBox(教程含源码)
- 微信小程序原生开发功能合集十:分步组件的封装
- 封装一个axios请求后台的通用方法
- [js高手之路] 跟GhostWu一起封装一个字符串工具库-扩展字符串位置方法(4)
- EasyExcel根据模板填充(多sheet页封装工具方法)
- OkHttp的封装和使用详解
- 【SystemVerilog基础】“封装、继承、多态” 深入探究
- 封装算法: 模板方法(Template Method)模式
- iOS Xcode10 封装生成.framework,导入新建工程测试可用
- Flutter开发 - 对于富文本展示的方法封装
- Android Dialog 简单封装
- KiCad 5.1.2 导入元件库、封装库和3D模型
- typeof不好判断null、Array,Object等,自己封装一个类型判断方法,可精确判断