当前位置: 首页 > news >正文

python+Request提取cookie

目录

参数

登录接口参数

​编辑

查询所有课程参数

python处理cookie。

提取cookie

使用json模块提取token

正则表达式re模块提取token

完整代码


参数

登录接口参数

查询所有课程参数

python处理cookie。

  1. 导入request包
    1. # 导入request包
      import requests
  2. 编写登录请求的查询参数
    1. # 编写请求
      # 登录参数
      login_param = {"phone":"15321919666","password":"123456",
      }
      # URL地址
      url_address_test = "http://www.edu2.com:8080/ssm_web/user/login"
  3. 接受响应数据
    1. # result_data_info 接受响应数据
      result_data_info = requests.post(url_address_test,data=login_param);
  4. 编写查询课程的url,并且接受
    1. # 查询课程URL
      query_all_course_address = "http://www.edu2.com:8080/ssm_web/course/findAllCourse"
      result_data_info = requests.post(query_all_course_address);
  5. 打印结果
    1. # 判断是否是JSON数据
      try:print(result_data_info.json())print("处理成功")except ValueError:print("返回结果不是JSON格式")print("响应内容是:")print(result_data_info.content)
  6. 运行程序
  7. 分析结果
    1. 在没有使用cookie的请求下
    2. 可以看到,服务器出现了错误
    3. 并且没有返回JSON数据
    4. 正常情况下这个接口会返回json数据
      1. 这个是POSTMAN返回结果
        1. Postnman可以自己管理cookie
      2. 这个是Jmeter中的返回结果
        1. Jmeter可以使用Http Cookie 管理器
        2. 或者自己提取
      3. 分析得出,发送请求的时候没有携带cookie和一些其他的参数
    5. 提取cookie

      1. # 提取登录请求的cookie
        login_cookie_info =  result_data_info.cookies print(" 登录接口中的cookie: ",login_cookie_info)
    6. 使用json模块提取token

      1. # 导入json模块
        import json
      2. json数据转化为字符串
        1. # json数据转化为字符串
          json_str_data =  json.dumps(json_data);
          print("json数据转化为字符串",json_str_data)
          
      3. 提取token

        1. login_token_info  = json.loads(json_str_data)['content']['access_token'];
          print(login_token_info)
      4. 发送查询课程请求
        1. # 查询课程URL
          query_all_course_address = "http://www.edu2.com:8080/ssm_web/course/findAllCourse"
          result_data_info = requests.post(url=query_all_course_address,cookies=login_cookie_info,headers={"content-type":"application/json;","Authorization":login_token_info},json={});
    7. 正则表达式re模块提取token

      1. 这里使用re模块使用正则表达式去提取token
      2. 导入re模块
        1. # 导入re模块
          import  re
      3. 正则表达式代码提取token

        1. # 使用正则表达式提取token
          re_token = re.findall(pattern=r"'access_token': '(.*?)'",string=str(result_data_info.json()))print("re_token的结果:" ,re_token)
        2. 正则表示式格式
          1. r"XXXXXXXXXXXXXX-XXXXXXX"
          2. . 代表任意字符
          3. + 左侧尽可能多的匹配
          4. ? 尽可能少的匹配
      4. 运行结果
        1. 通过数据比对,可以看到已经成功提取
    8. 完整代码

# 导入request包import requests# 导入json模块
import json# 导入re模块
import  re# 编写请求
# 登录参数
login_param = {"phone":"15321919666","password":"123456",
}
# URL地址
url_address_test = "http://www.edu2.com:8080/ssm_web/user/login"# result_data_info 接受响应数据
result_data_info = requests.post(url_address_test,data=login_param);
# 打印响应结果
print(result_data_info.json())# 提取登录请求的cookie
login_cookie_info =  result_data_info.cookiesprint(" 登录接口中的cookie: ",login_cookie_info)
json_data = result_data_info.json()
# 提取token# json数据转化为字符串
json_str_data =  json.dumps(json_data);
print("json数据转化为字符串",json_str_data)login_token_info  = json.loads(json_str_data)['content']['access_token'];
print(login_token_info)print("json_token ",login_token_info)# 使用正则表达式提取token
re_token = re.findall(pattern=r"'access_token': '(.*?)'",string=str(result_data_info.json()))print("re_token的结果:" ,re_token)# 查询课程URL
query_all_course_address = "http://www.edu2.com:8080/ssm_web/course/findAllCourse"
result_data_info = requests.post(url=query_all_course_address,cookies=login_cookie_info,headers={"content-type":"application/json;","Authorization":login_token_info},json={});# json={}# 判断是否是JSON数据
try:print(result_data_info.json())print("处理成功")except ValueError:print("返回结果不是JSON格式")print("响应内容是:")print(result_data_info.content)

http://www.dtcms.com/a/279309.html

相关文章:

  • 电脑升级Experience
  • python transformers笔记(Trainer类)
  • 代码随想录算法训练营第三十五天|416. 分割等和子集
  • LLM表征工程还有哪些值得做的地方
  • 内部文件审计:企业文件服务器审计对网络安全提升有哪些帮助?
  • 防火墙技术概述
  • Qt轮廓分析设计+算法+避坑
  • Redis技术笔记-主从复制、哨兵与持久化实战指南
  • 第五章 uniapp实现兼容多端的树状族谱关系图,剩余组件
  • 学习C++、QT---25(QT中实现QCombobox库的介绍和用QCombobox设置编码和使用编码的讲解)
  • SQL ORM映射框架深度剖析:从原理到实战优化
  • 【Unity】MiniGame编辑器小游戏(十三)最强射手【Shooter】(下)
  • ElasticSearch重置密码
  • 嵌入式 Linux开发环境构建之Source Insight 的安装和使用
  • c++算法二
  • 不同Linux版本下安装Synopsys工具的差异与选择建议
  • PyTorch 数据加载全攻略:从自定义数据集到模型训练
  • [Pytorch]深度学习-part1
  • 策略模式及优化
  • LangChain面试内容整理-知识点16:OpenAI API接口集成
  • Linux操作系统之信号:信号的产生
  • 观察应用宝进程的自启动行为
  • Spring Boot启动原理:从main方法到内嵌Tomcat的全过程
  • vue vxe-tree 树组件加载大量节点数据,虚拟滚动的用法
  • 每日mysql
  • # 检测 COM 服务器在线状态
  • 在Linux下git的使用
  • 7.14练习案例总结
  • 渗透第一次总结
  • ThreadLocal内部结构深度解析(Ⅰ)