【原创】Selenium获取请求头、响应头

本文仅供学习交流使用,如侵立删!

Selenium获取请求头、响应头

操作环境

  • win10 、 mac
  • Python3.9
  • selenium、seleniumwire

selenium是没有办法直接获取请求的详细Headers,很多时候我们我们是需要提取相关的参数来做进一步使用比如token之类的,这里推荐使用一个SeleniumWire模块来达到目的
在这里插入图片描述

Selenium-wire模块介绍

Selenium-wire官方文档
安装:pip install selenium-wire
项目介绍
Selenium Wire 扩展了 Selenium 的 Python 绑定,让您可以访问浏览器发出的底层请求。 您编写代码的方式与编写 Selenium 的方式相同,但您会获得额外的 API 来检查请求和响应并动态更改它们。

Compatibilty

  • Python 3.6+
  • Selenium 3.4.0+
  • Chrome, Firefox and Remote Webdriver supported
    在这里插入图片描述

获取请求headers

from seleniumwire import webdriver


def get_request_headers():
    """
    获取请求头headers详细信息
    """
    driver = webdriver.Chrome()
    driver.get('https://www.baidu.com')
    for request in driver.requests:
        print('请求headers:')
        print(request.headers)
        break
    driver.quit()

在这里插入图片描述

获取响应headers

from seleniumwire import webdriver


def get_response_headers():
    """
    获取响应头headers详细信息
    """
    driver = webdriver.Chrome()
    driver.get('https://www.baidu.com')
    for request in driver.requests:
        print('响应headers:')
        print(request.response.headers)
        break
    driver.quit()

在这里插入图片描述

获取所有加载的url

from seleniumwire import webdriver


def get_request_headers():
    """
   获取所有加载的url
    """
    driver = webdriver.Chrome()
    driver.get('https://www.baidu.com')
    print('获取所有加载的url:')
    for request in driver.requests:
        print(request.url)
    driver.quit()

在这里插入图片描述
这里就先分享这几个方法,基本上整个请求流程中所有的数据都是可以拿到的,具体可以查看官方文档或直接查看源码


资源下载

https://download.csdn.net/download/qq_38154948/85204671


本文仅供学习交流使用,如侵立删!

posted @   拉灯的小手  阅读(671)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示