使用 python 批量处理 Jmeter 请求头

在使用 jmeter 录制并处理脚本的时候,在处理登录 token 或者其他 HTTP 请求头时,一般把这些请求头提取出到自己建一个公共的 HTTP 信息头管理器,然后开始录制脚本。
但是录制的时候会发现录制出来的 HTTP 信息头管理器还会存在这些公共请求头,我们还要认为删除或者通过正则表达式提取器来替换,第一种略显麻烦,但通过代码可以实现一键删除。

实现

本人使用 python 3.9 直接对 jmx 文件进行文本处理,使用到了 lxml 对节点进行处理。

处理单位以文件夹形式,使用的时候把需要处理的 jmx 文件放进一个空的文件夹,该文件夹的绝对路径即代码中的变量 jmx_folder,需要删除的 HTTP 请求即代码中的变量 header,使用的时候对应修改这两个变量即可。

代码

import os
from lxml import etree
import shutil
import re

def jmx_anal(jmx_folder,header):
    files = os.listdir(jmx_folder)
    # 迭代读取文件夹下的 jmx 文件
    jmx_files = [file for file in files if '.jmx' in file]
    parser = etree.XMLParser(encoding='utf-8')
    for jmx_file in jmx_files:
        tree = etree.parse(jmx_folder+'/'+jmx_file,parser = parser)
        # 获取所有事务控制器
        for ele in tree.iter(tag='elementProp'):
            # 删除对应的 HTTP 请求头
            if ele.get('name') == header:
                ele.clear()
        # lxml 删除节点并不完全,不会删除表示结尾的  符号,所以还需要进一步处理
        text = etree.tostring(tree,encoding='utf-8').decode('utf-8')
        pattern = re.compile('elementProp/><')
        new_text = re.sub(pattern,r'',text)
        document = open(jmx_folder+'/'+jmx_file, 'w',encoding="utf-8")
        document.write('<!--?xml version="1.0" encoding="UTF-8"?-->\r')
        document.write(new_text)
        document.close()

if __name__ == "__main__":
    # 使用的时候修改以下两个变量为自己的环境即可
    jmx_folder = 'D:\Ginny'
    header = 'Authorization'
    jmx_anal(jmx_folder,header)
上一篇:全球与中国异构醇市场运营状况与前景动态分析报告2022~2027年


下一篇:nginx部署前后端分离项目(spring boot + vue)