news 2026/6/9 19:49:21

CNAS软件测评机构【Gatling查询参数和表单数据queryParam、formParam和multipartFormData参数处理方式】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CNAS软件测评机构【Gatling查询参数和表单数据queryParam、formParam和multipartFormData参数处理方式】

Gatling的queryParam、formParam和multipartFormData是构建HTTP请求参数的三种主要方式,分别对应不同的协议标准和数据格式。

1. queryParam:构建URL查询字符串

queryParam 用于构建URL中的查询字符串(?key1=value1&key2=value2),主要应用于GET请求,也可用于POST、PUT等。

基础和动态用法

import io.gatling.core.Predef._ import io.gatling.http.Predef._ // 基础静态参数 http("基础查询请求") .get("/api/search") .queryParam("category", "books") // ?category=books .queryParam("sort", "price_desc") // 动态参数(从Session中提取) .exec( http("动态查询请求") .get("/api/search") .queryParam("userId", "${userId}") // EL表达式引用Session变量 .queryParam("page", "${currentPage}") .queryParam("query", "#{randomString(10)}") // 使用Gatling内置函数 )

高级用法-参数列表和条件参数

// 构建多值参数(数组) .queryParam("tags", "java,scala,performance") // 方式1:逗号分隔 .queryParam("tags", Seq("java", "scala", "performance")) // 方式2:Scala序列 // 条件性添加参数 .exec(session => { val userLevel = session("userLevel").as[String] val params = if (userLevel == "vip") { Map("vip_only" -> "true", "premium" -> "yes") } else { Map("standard" -> "true") } session.set("queryParams", params) }) .exec( http("条件查询") .get("/api/content") .queryParam("basic", "always") // 动态添加多个参数 .queryParamList("#{queryParams}") )

2. formParam-标准表单编码

formParam 用于 application/x-www-form-urlencoded 格式,这是HTML表单的默认提交格式。

基础和批量提交

// 基础表单提交(模拟登录) http("用户登录") .post("/login") .header("Content-Type", "application/x-www-form-urlencoded") .formParam("username", "${username}") .formParam("password", "${password}") .formParam("remember_me", "true") // 批量添加参数(适用于参数数量动态变化) .exec(session => { val formData = Map( "name" -> "测试用户", "email" -> "test@zmtests.com", "age" -> "30", "subscription" -> "premium" ) session.set("formDataMap", formData) }) .exec( http("批量表单提交") .post("/profile/update") .formParamList("#{formDataMap}") // 批量添加所有参数 )

编码和特殊字符处理

// Gatling自动进行URL编码,但需注意特殊情况 .formParam("search_query", "Gatling & Performance Testing") // 编码为:Gatling%20%26%20Performance%20Testing // 处理已编码值(使用原始字符串) .formParam("pre_encoded", RawFileBodyPart("已编码的数据.txt")) // 或手动控制编码 .exec(session => { val rawValue = "特殊&字符=测试" val encodedValue = java.net.URLEncoder.encode(rawValue, "UTF-8") session.set("safeValue", encodedValue) })

3. multipartFormData-混合表单数据(含文件上传)

multipartFormData 用于 multipart/form-data 格式,支持混合文本字段和二进制文件上传。

基础文件上传

// 基本文件上传(小文件) http("上传单文件") .post("/upload") .bodyPart(RawFileBodyPart("file", "test.pdf")) // 从resources文件夹读取 .bodyPart(StringBodyPart("description", "性能测试报告PDF文档")) // 指定MIME类型和字符集 http("上传带元数据的文件") .post("/upload") .bodyPart( RawFileBodyPart("document", "report.pdf") .contentType("application/pdf") // 指定MIME类型 .fileName("性能报告.pdf") // 自定义客户端文件名 ) .bodyPart( StringBodyPart("notes", "这是最终版本的报告") .charset("UTF-8") // 指定字符集 )

高级用法-动态多文件和流式处理

// 动态构建多文件上传 val fileFeeder = csv("test_files.csv").random // 从CSV文件获取文件信息 exec(feed(fileFeeder)) .exec( http("动态多文件上传") .post("/batch-upload") .bodyPart(RawFileBodyPart("file1", "${file1_path}")) .bodyPart(StringBodyPart("category1", "${file1_category}")) .bodyPart(RawFileBodyPart("file2", "${file2_path}")) .bodyPart(StringBodyPart("category2", "${file2_category}")) .bodyPart(StringBodyPart("uploader", "${userId}")) ) // 大文件处理和流式上传(避免内存溢出) http("流式上传大文件") .post("/upload-large") .processRequestBody( bodyParts => bodyParts.map { case part: RawFileBodyPart => part.toStream // 转换为流处理 case other => other } ) .bodyPart( RawFileBodyPart("video", "large_video.mp4") .contentType("video/mp4") .transferEncoding("binary") // 二进制传输编码 ) .bodyPart(StringBodyPart("comment", "大文件测试"))

内存优化和性能配置

// Gatling配置中调整multipart相关参数 val httpProtocol = http .baseUrl("http://zmtests.com") .multipartBoundary("----WebKitFormBoundaryABC123") // 自定义边界 .disableWarmUp // 对于大文件测试,禁用热身以减少内存波动 .shareConnections // 共享连接提高效率 // 在具体请求中控制缓冲区大小 http("优化文件上传") .post("/upload") .bodyPart( RawFileBodyPart("data", "large.bin") .contentType("application/octet-stream") ) .requestTimeout(60000) // 增加超时时间

注意事项

参数编码一致:Gatling自动处理URL编码,保证测试数据和实际生产数据编码一致

Session变量管理:对于动态参数,合理使用Session来存储和管理参数状态

文章来源:卓码软件测评

精彩推荐:点击蓝字即可
软件负载测试API自动化测试软件测试第三方软件测试软件性能测试软件测试机构

文件资源管理:

// 使用feeder动态选择文件 val fileFeeder = Iterator.continually(Map( "filePath" -> s"data/test_${java.util.UUID.randomUUID().toString}.txt" )) // 测试后清理生成的文件 after { println("测试完成,清理临时文件") // 文件清理逻辑 }

性能监控:

queryParam:注意URL长度和参数解析

formParam:注意编码/解码CPU消耗

multipartFormData:注意内存使用、I/O吞吐和网络延迟

调试

// 1. 打印实际请求详情 .exec { session => // 通过日志或调试器查看实际构建的请求 println(s"请求参数: ${session("requestParams").asOption[String]}") session } // 2. 使用Gatling HTTP日志 val httpProtocol = http .baseUrl("http://zmtests.com") .enableHttp2 .disableCaching .silentResources // 静默资源请求 .silentUri(".*\\.(css|js|png|gif).*") .disableFollowRedirect .maxConnectionsPerHost(10) .acceptHeader("*/*") .userAgentHeader("Gatling/3.0") .warmUp("http://zmtests.com/health") // 预热 .check(status.is(200)) // 基础检查

这三种参数构建方式能精准模拟从简单查询到复杂文件上传的各种实际业务情形。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 17:29:28

测试一个区块链智能合约的完整流程

智能合约测试的必要性与挑战 在区块链技术日益融入金融、供应链、身份认证等核心领域的今天,智能合约作为承载自动执行业务逻辑的“链上代码”,其安全性与可靠性至关重要。一次微小的代码漏洞,就可能导致数百万甚至上亿美元资产的永久损失或…

作者头像 李华
网站建设 2026/6/10 7:54:15

艾体宝洞察 | Redis vs ElastiCache:哪个更具成本效益?

ElastiCache 最大的成本驱动因素很容易被忽视:您永远无法将节点的全部内存用作可用的键空间。根据 AWS 的官方文档,默认情况下有 25% 的内存被预留用于备份和复制等操作,这部分内存是不可用的。因此,客户实际可用的容量要小于实例…

作者头像 李华
网站建设 2026/6/10 4:39:30

产教融合新路径:无人机基础认知 AI+虚仿 实训室破解人才培养困境

随着“新双高”计划深入推进,职业教育迎来提质培优的关键时期。无人机产业作为低空经济核心组成部分,正面临人才供给与产业需求脱节的现实困境。在产教融合政策引领下,我们创新推出无人机基础认知“AI虚仿”创新实训室,通过虚拟仿…

作者头像 李华
网站建设 2026/6/10 7:54:33

java学习--System

Java 中的 System 类,它是 java.lang 包下的核心系统类,提供了大量与系统交互的静态方法和静态属性,用于访问系统环境、执行系统级操作(如输入输出、垃圾回收、系统退出等),下面从核心特性、静态属性、常用…

作者头像 李华
网站建设 2026/6/10 7:55:10

java计算机毕业设计物流管理系统 基于SpringBoot的电商物流全链路信息化平台 面向新零售的智能配送与仓储一体化系统

计算机毕业设计物流管理系统1446p9(配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。当包裹在屏幕上轻轻一点就启程,它背后其实是一场跨城市、跨仓库、跨角色的数据接力…

作者头像 李华