browsermobproxy + selenium 获取接口json

browsermobproxy + selenium 获取接口json数据

第三方库各版本情况:

selenium==4.12.0 browsermob-proxy==0.8.0

browsermob-proxy-2.1.4-bin.zip(外部程序)

1.导入第三方库

coding=utf-8

import time

from selenium.webdriver.common.by import By

from selenium import webdriver

from selenium.webdriver.firefox.options import Options

import json

from browsermobproxy import Server

2.运行proxy服务器

server = Server('browsermob-proxy-2.1.4\\bin\\browsermob-proxy.bat')

server.start()

proxy = server.create_proxy(params={'trustAllServers':'true'}) #信任所有证书,针对自签名证书

创建一个Selenium WebDriver的代理配置

print(proxy.port)

3.设置options参数

options = Options()

options.add_argument('--headless')

#火狐设置这五行代理就OK了;

options.set_preference("network.proxy.type", 1)

options.set_preference("network.proxy.http", '127.0.0.1') #设置http代理服务器

options.set_preference("network.proxy.http_port", proxy.port) #设置http代理服务器端口

options.set_preference("network.proxy.ssl", '127.0.0.1') #设置https代理服务器

options.set_preference("network.proxy.ssl_port", proxy.port) #设置https代理服务器端口

'''

options.add_argument("--ignore-certificate-errors")

options.add_argument("disable-gpu")

options.add_argument("--disable-extensions")

options.add_argument('--proxy-server={0}'.format(proxy.proxy)) #这四个选项是谷歌的

创建一个Firefox配置文件

profile = webdriver.FirefoxProfile()

添加受信任的SSL证书 (这部分留个记录)

profile.accept_untrusted_certs = True

profile.assume_untrusted_cert_issuer = False

profile.set_preference("security.enterprise_roots.enabled", True)

profile.set_preference("security.certerrors.recordEventTelemetry", False)

profile.set_preference("security.certerrors.mitm.priming.enabled", False)

profile.set_preference("security.family_safety.mode", 0)

profile.set_preference("security.OCSP.enabled", 0)

profile.set_preference("security.OCSP.require", False)

profile.set_preference("security.ssl.enable_ocsp_stapling", False)

profile.set_preference("security.enterprise_roots.enabled", True)

profile.set_preference("security.enterprise_roots.enabled", True)

profile.add_extension(extension=certificate_file_path)

options.set_capability("moz:firefoxOptions", {"profile": profile})

options.add_argument('--trust-all-certs')

options.add_argument(f'--profile={certificate_file_path}')

'''

4.设置过滤器、创建火狐浏览器实例

#设置代理过滤器

proxy.new_har("test",options={'captureHeaders': True, 'captureContent': True})

#services=webdriver.FirefoxService('geckodriver.exe')

driver = webdriver.Firefox(options=options)

5.访问链接获取接口数据(json格式)

#设置url

url='https://xxxx.xx'

driver.get(url)

time.sleep(3)

proxy.wait_for_traffic_to_stop(1, 60)

result = proxy.har

for entry in result'log''entries':

_url = entry'request''url'

根据URL找到数据接口

respose_rul='https://xxxx.xx' #api接口链接特征

if respose_rul in _url:

print(_url)

_response = entry'response'

_content = _response'content''text'

返回的均是字符串包着字典,为了提高可读性,先将数据转换成python字典,再转成json数据

content_dict = json.loads(_content)

print(content_dict)

#content_json = json.dumps(content_dict,indent=4)

#content_json=json.loads(content_json)

with open('respose.txt','w',encoding='gbk')as f:

json.dump(content_dict,f,indent=4)

#print(content_dict)

获取接口返回内容

#print(_content)

相关推荐
ClouGence14 小时前
Selenium、Playwright、CueCast 深度对比:Web 自动化测试工具怎么选
selenium·测试
Venuslite5 天前
从 Unexpected token < 到 Extra data:一次讲清 JSON 解析错误的排查思路
json
疯狂SQL11 天前
手写高性能在线 JSON 工具|Web Worker 工程化打包 + 语法自动修复 + 多语言代码生成实战
typescript·json·next.js·web worker·前端性能优化·esbuild·源码实战
程序员小远16 天前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
terry60016 天前
5G视频短信服务商选型全攻略:通道资源、架构能力与成本评估2026最新标准
大数据·人工智能·5g·json·asp.net·信息与通信·数据库架构
LT101579744416 天前
2026年Web自动化测试工具选型指南:多浏览器兼容解决方案
前端·测试工具·自动化
前网易架构师-高司机16 天前
带标注的辣椒病叶数据集,识别率95.9%,可识别三种病害和健康叶子,9916张图,支持yolo,coco json,voc xml,文末有模型训练代码
yolo·json·数据集·病害·叶病·病叶·辣椒
PixelBai16 天前
JSON扁平化使用教程:从入门到精通
json