解决fidder小黑怪倒出JMeter文件缺失域名、请求头

news/2024/9/13 23:33:15/ 标签: jmeter, fiddler

解决fidder小黑怪倒出JMeter文件缺失域名、请求头

1、目录结构:

在这里插入图片描述

2、代码

'''
coding:utf-8
@Software:PyCharm
@Time:2024/7/10 14:02
@Author:Dr.zxy
'''
import zipfile
import os
import xml.etree.ElementTree as ET
import re#定义信息头
headers_to_extract = ['Host', 'Connection', 'Content-Length', 'apiversion', 'apicode','User-Agent', 'format', 'content-type', 'accept', 'pagecode','x-secure-opt-log', 'appcode', 'Origin', 'Referer','Accept-Language', 'Accept-Encoding', 'Cookie'
]# 定义函数解压 .saz 文件
def extract_saz(saz_file):# 创建一个目录来存放解压后的内容extract_folder = saz_file.replace('.saz', '_extracted')os.makedirs(extract_folder, exist_ok=True)# 打开 saz 文件with zipfile.ZipFile(saz_file, 'r') as zip_ref:# 解压所有文件到 extract_folderzip_ref.extractall(extract_folder)return extract_folder# 定义函数将提取的文件重命名为 .txt
def convert_to_txt(extract_folder):# 遍历提取的文件夹中的所有文件for root, _, files in os.walk(extract_folder):for file in files:# 如果文件不是 .txt 文件,则重命名为 .txtif not file.endswith('.txt'):original_path = os.path.join(root, file)new_path = os.path.join(root, os.path.splitext(file)[0] + '.txt')os.rename(original_path, new_path)
#url填充
def update_domain_from_comments(xml_file):#加载文件tree = ET.parse(xml_file)root = tree.getroot()for sampler in root.findall('.//HTTPSamplerProxy'):testplan_comments = sampler.find(".//stringProp[@name='TestPlan.comments']")if testplan_comments is not None:domain_value = testplan_comments.textdomain_prop = sampler.find(".//stringProp[@name='HTTPSampler.domain']")if domain_prop is not None:domain_prop.text = domain_valuetree.write(xml_file, encoding='utf-8', xml_declaration=True)#信息头添加序号
def update_testname(filename):tree = ET.parse(filename)root = tree.getroot()header_managers = root.findall('.//HeaderManager')for idx, header_manager in enumerate(header_managers):# 信息头管理器添加序号 001   002new_testname = f'{idx:03}-HTTP信息头管理器'  # {:03} 确保3位数字的前导为零header_manager.set('testname', new_testname)# 写到Jmeter文件tree.write(filename, encoding='utf-8', xml_declaration=True)# 读取文件内容with open(filename, 'r', encoding='utf-8') as file:content = file.read()# 定义要删除的 XML 片段pattern = r'<HeaderManager guiclass="HeaderPanel" testclass="HeaderManager" testname="000-HTTP信息头管理器" enabled="true">.*?</HeaderManager>\s*<hashTree\s*/>'# 使用正则表达式删除匹配的部分new_content = re.sub(pattern, '', content, flags=re.DOTALL)# 将修改后的内容写回文件with open(filename, 'w', encoding='utf-8') as file:file.write(new_content)# 从文件中读取头并转换为JMeter Header Manager格式的函数
def convert_to_jmeter_xml(directory, headers_to_extract):# 遍历目录中的文件for filename in os.listdir(directory):if filename.endswith("_c.txt"):file_path = os.path.join(directory, filename)#提取下划线前的数值numeric_value = filename.split('_')[0].zfill(3)# 处理文件以提取标头headers = {}with open(file_path, 'r', encoding='utf-8') as file:content = file.read()for header in headers_to_extract:match = re.search(rf'^{header}: (.+)$', content, flags=re.MULTILINE)if match:headers[header] = match.group(1)# 生成JMeter标头管理器XMLheader_xml = ''for header, value in headers.items():header_xml += f'''<elementProp name="" elementType="Header"><stringProp name="Header.name">{header}</stringProp><stringProp name="Header.value">{value}</stringProp></elementProp>'''# 包裹式格式jmeter_xml = f'''<HeaderManager guiclass="HeaderPanel" testclass="HeaderManager" testname="{numeric_value}-HTTP信息头管理器" enabled="true"><collectionProp name="HeaderManager.headers">{header_xml}</collectionProp></HeaderManager>'''# 将JMeter XML内容写入新文件output_filename = f'{numeric_value}_jmeter.xml'output_path = os.path.join(directory, output_filename)with open(output_path, 'w', encoding='utf-8') as output_file:output_file.write(jmeter_xml)#print(f'Converted {filename} to {output_filename}')# 第一步:遍历所有的<HeaderManager>标签,提取testname属性中'-'前的值
def extract_testnames(filename):testnames = []tree = ET.parse(filename)root = tree.getroot()for header_manager in root.findall('.//HeaderManager'):testname = header_manager.get('testname', '')if '-' in testname:testnames.append(testname.split('-')[0])return testnames# 第二步:读取替换目标文件的内容
def read_file_content(filename):with open(filename, 'r', encoding='utf-8') as file:content = file.read()return content# 第三步:替换<HeaderManager>标签节点的内容为指定文件的内容
def replace_header_manager_content(filename, testname, replacement_content):# 解析 XML 文件tree = ET.parse(filename)root = tree.getroot()# 查找所有 <HeaderManager> 节点for header_manager in root.findall('.//HeaderManager'):# 检查 testname 属性是否以指定的 testname 开头if header_manager.get('testname', '').startswith(testname):# 清空 <HeaderManager> 节点的内容header_manager.clear()# 设置新的内容header_manager.text = replacement_content# 保存修改后的 XML 文件tree.write(filename, encoding='utf-8', xml_declaration=True)def modify_jmx_file(input_file, output_file):try:# 读取原始文件内容with open(input_file, 'r', encoding='utf-8') as f:content = f.read()# 替换操作content = content.replace('<HeaderManager>', '')content = content.replace('</HeaderManager>', '')content = content.replace('&lt;', '<')content = content.replace('&gt;', '>')# 写入修改后的内容到目标文件with open(output_file, 'w', encoding='utf-8') as f:f.write(content)#print(f'文件处理完成,修改后的文件保存为 {output_file}')except FileNotFoundError:print(f'Error: File {input_file} not found.')#修改填充的 jmeter
jmx_filename = 'jmx/33n.jmx'
#新的文件名称
output_file = 'jmx/new_modified.jmx'if __name__ == "__main__":# 替换为你的.saz 文件路径saz_file_path = 'files/333.saz'# 解压 .saz 文件extract_folder = extract_saz(saz_file_path)# 将提取的文件重命名为 .txtconvert_to_txt(extract_folder)print(f"step1---fidder转换完成!提取文件存放在:{extract_folder}")update_domain_from_comments(jmx_filename)print(f"step2---url填充完毕")update_testname(jmx_filename)print(f"step3---信息头管理器【序号】添加完成")convert_to_jmeter_xml(extract_folder+"/raw", headers_to_extract)print(f"step4---信息头管理器【新节点·生成】生成完成")# 第一步:提取所有testname中'-'前的值testnames = extract_testnames(jmx_filename)# 第二步和第三步:针对每个testname,读取对应的XML文件并替换内容for testname in testnames:xml_filename = os.path.join(extract_folder+"/raw/", f'{testname}_jmeter.xml')if os.path.exists(xml_filename):replacement_content = read_file_content(xml_filename)replace_header_manager_content(jmx_filename, testname, replacement_content)else:print(f"Warning: File {xml_filename} not found.")print(f"step5---信息头管理器【新节点·替换】完成")modify_jmx_file(jmx_filename, output_file)print(f"step6---信息头管理器【新节点·替换清洗】完成")

3、注意事项

4、结果

在这里插入图片描述


http://www.ppmy.cn/news/1475838.html

相关文章

Spring-Aop源码解析

本文主要讲解spring实现aop的相关源码学习教程&#xff0c;以aop.xml配置文件的方式为例&#xff0c;讲解如何将配置文件的标签解析成bean定义信息&#xff0c;存放到beanfactory中。以及advisor的bean定义信息以及实例化的过程&#xff1b;对哪些类进行代理&#xff0c;以及判…

[数仓]十二、离线数仓(Atlas元数据管理)

第1章 Atlas入门 1.1 Atlas概述 Apache Atlas为组织提供开放式元数据管理和治理功能,用以构建其数据资产目录,对这些资产进行分类和管理,并为数据分析师和数据治理团队,提供围绕这些数据资产的协作功能。 Atlas的具体功能如下: 元数据分类 支持对元数据进行分类管理,例…

DDD学习笔记七

将设计模式应用于模型设计 策略模式 策略模式着重解决以下类型的需求&#xff1a; ❑ 算法与多种变体需要不时替换。 ❑ 未来有新增的算法。 ❑ 一个类中某个行为有较多的分支&#xff0c;且需要时常维护。 ❑ 希望隐藏算法的逻辑或数据。 策略模式的建模步骤如下&#xff1a;…

C 语言 do while 语句

do while循环是 C 语言中的一种循环结构&#xff0c;它至少执行一次循环体内的代码&#xff0c;然后再根据条件判断是否继续执行。这与 while 循环不同&#xff0c;while循环在开始时就会检查条件&#xff0c;如果条件不成立&#xff0c;则循环体内的代码一次也不会执行。 下面…

聊聊自动驾驶中的LiDAR和Radar

LiDAR&#xff08;光检测与测距&#xff09;和Radar&#xff08;无线电波检测与测距&#xff09;是两种不同的遥感技术&#xff0c;它们在原理和应用上存在一些区别&#xff1a; 原理上的区别&#xff1a; LiDAR&#xff1a; 利用激光脉冲进行测距。通过测量激光从发射到反射…

在生产环境中部署Elasticsearch:最佳实践和故障排除技巧——安装篇(一)

#在生产环境中部署Elasticsearch&#xff1a;最佳实践和故障排除技巧——安装篇&#xff08;一&#xff09; 前言 关键字&#xff1a; 机器学习 人工智能 AI chatGPT 学习 实现 使用 搭建 深度 python 事件 远程 docker mysql安全 技术 部署 技术 自动化 代码 文章目录 - -…

uniapp 实现上传文件的功能

上传单个文件 <script setup>const handleUploadClick () > {console.log("上传文件")uni.chooseImage({success: (chooseImageRes) > {const tempFilePaths chooseImageRes.tempFilePaths;console.log("用户选择的图片&#xff1a;", temp…

数字化赋能,加油小程序让出行更便捷高效

在快节奏的现代生活中&#xff0c;每一次加油不仅是车辆续航的必要步骤&#xff0c;也成为了人们日常生活中不可或缺的一环。随着科技的飞速发展&#xff0c;传统加油模式正逐步向智能化、便捷化转型&#xff0c;其中&#xff0c;加油小程序作为这股浪潮中的佼佼者&#xff0c;…

FastAPI 学习之路(四十四)WebSockets

我们之前的分析都是基于http的请求&#xff0c;那么如果是websockets可以支持吗&#xff0c;答案是可以的&#xff0c;我们来看下是如何实现的。 from fastapi import WebSocket, FastAPI from fastapi.responses import HTMLResponseapp FastAPI()html """&…

WEB前端03-CSS3基础

CSS3基础 1.CSS基本概念 CSS是Cascading Style Sheets&#xff08;层叠样式表&#xff09;的缩写&#xff0c;它是一种对Web文档添加样式的简单机制&#xff0c;是一种表现HTML或XML等文件外观样式的计算机语言&#xff0c;是一种网页排版和布局设计的技术。 CSS的特点 纯C…

[Day 29] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

區塊鏈的供應鏈管理應用 區塊鏈技術自2008年比特幣誕生以來&#xff0c;逐漸被廣泛應用於各種領域&#xff0c;其中供應鏈管理是其最有潛力的應用之一。區塊鏈的去中心化、不可篡改和透明性特點&#xff0c;使其在解決傳統供應鏈中的信息不對稱、數據篡改和信任問題方面具有顯…

C调用C++接口

C文件 #include <ctype.h> #include <sys/time.h> #include <sys/stat.h> #include <time.h> #include <stdio.h> #include <stdlib.h> #include <stdint.h> #include <stdbool.h> #include <unistd.h> #include <s…

Macbook pro插移动硬盘没反应,Macbook pro移动硬盘读不了怎么办 macbook插移动硬盘后无法使用

为了弥补Macbook pro硬盘容量的缺失&#xff0c;我们有时候会使用到外接硬盘或移动硬盘。一般来说&#xff0c;这些硬盘都是即插即用的&#xff0c;可能部分要安装插件。不过&#xff0c;在一些特殊情况下&#xff0c;也会遇到插硬盘没反应等问题。本文会给大家解答Macbook pro…

RustChinaConf 2024(Rust中国大会2024)号集令

自六月官宣以来&#xff0c;Rust中国大会2024受到了众多厂商的青睐。目前已经确定的重量级赞助商有&#xff1a; ICP&#xff08;互联网计算机&#xff09;非凸科技在线途游蚂蚁金服JetBrain GEAR Foundation INFINI Labs Greptime 等 其中钻石赞助仅剩少量名额 请有意向赞助大…

勒索防御第一关 亚信安全AE防毒墙全面升级 勒索检出率提升150%

亚信安全信舷AE高性能防毒墙完成能力升级&#xff0c;全面完善勒索边界“全生命周期”防御体系&#xff0c;筑造边界勒索防御第一关&#xff01; 勒索之殇&#xff0c;银狐当先 当前勒索病毒卷携着AI技术&#xff0c;融合“数字化”的运营模式&#xff0c;形成了肆虐全球的网…

Spring Boot 3.3 【二】Spring Boot自动配置机制深度解析

简单动作&#xff0c;深刻联结。在这技术海洋&#xff0c;我备好舟&#xff0c;等你扬帆。启航吧&#xff01; &#x1f31f;点击【关注】&#xff0c;解锁定期的技术惊喜&#xff0c;让灵感与知识的源泉不断涌动。 &#x1f44d;一个【点赞】&#xff0c;如同心照不宣的默契&a…

【数智化案例展】吉林省消防救援总队——基于大语言模型的119智慧助手

‍ 嘉诚信息案例 本项目案例由嘉诚信息投递并参与数据猿与上海大数据联盟联合推出的《2024中国数智化转型升级创新服务企业》榜单/奖项评选。 大数据产业创新服务媒体 ——聚焦数据 改变商业 随着信息时代的迅猛发展&#xff0c;消防人员正面临前所未有的知识爆炸挑战。为了高…

【数据结构】:时间和空间复杂度

目录 如何衡量一个代码的好坏 时间复杂度 概念 计算方法 实例计算 【实例1】 【实例2】 【实例3】 【实例4】&#xff1a;冒泡排序的时间复杂度 【实例5】&#xff1a;二分查找的时间复杂度 【实例6】&#xff1a;阶乘递归的时间复杂度 【实例7】&#xff1a;斐波那契…

防火墙双机热备和带宽管理

拓扑图 实验要求 1.对现有网络进行改造升级&#xff0c;将当个防火墙组网改成双机热备的组网形式&#xff0c;做负载分担模式&#xff0c;游客区和DMZ区走FW5&#xff0c;生产区和办公区的流量走FW4 2.办公区上网用户限制流量不超过100M&#xff0c;其中销售部人员在其基础上…

类和对象(2

*续上文中的运算符重载 4 重载运算符时,有前置和后置的,运算符重载的函数名都是operator, 无法很好区分 所以c规定,后置重载时,增加一个int形参 与前置做区分 5 重载<<和>>时需要重载为全局函数, 因为重载为成员函数时, this指针默认抢占了第一个形参位, 第一个形参…