使用 CSV 作为动态参数的输入
添加->配置元件->CSV Data Set Config 添加动态参数。如下:

CSV 文件的内容如下:这里随意写了几个。变量名列表。对应参数文件每列的变量名,类似 Excel 文件的文件头,起到标示作用,同时也是后续引用的标识符,建议采用有意义的英文标示。例如:loginToken 可以被用变量名来引用:${loginToken}。多个变量名之间必须用分隔符分隔。如果该项为空,则文件首行会被读取并解析为列名。
1 | loginToken |
JMeter 中配置如下:

参数解释
- 名称(Name):脚本中显示的该元件的描述性名称,必须填写。
- 注释(Comments):对该元件的说明信息。(非必填写)
- 文件名(Filename):待读取文件的名称。可以写入绝对路径,也可以写入相对路径(相对于 bin 目录或者脚本文件所在目录),如果直接写文件名,则该文件一定要放在 bin 目录中。对于分布式测试,主机和远程机中相应目录下应该有相同的 CSV 文件,必须填写。(建议填写相对路径,避免脚本迁移时需要修改路径)
- 文件编码(File Encoding):文件读取时的编码格式,不填则使用操作系统的编码格式。(非必填写,下拉菜单可选,一般情况下选择 UTF-8 即可)
- 变量名称(Variable Names):变量名列表。对应参数文件每列的变量名,类似 Excel 文件的文件头,起到标示作用,同时也是后续引用的标识符,建议采用有意义的英文标示。例如:
eid,name可以被用变量名来引用:${eid},${name}。多个变量名之间必须用分隔符分隔。如果该项为空,则文件首行会被读取并解析为列名。(非必填写) - 忽略首行(Ignore first line):是否忽略首行,如果 CSV 文件中没有表头,则选择 False,必须填写。
- 分隔符(Delimiter):参数分隔符,将一行数据分隔成多个变量,默认为逗号,也可以使用
\t。如果一行数据分隔后的所获得的变量数,比 Variable Names 中定义的变量少,这些变量将保留以前的值(如果有值的话),必须填写。 - 是否允许带引号?(Allow quoted data?):是否允许变量使用双引号,允许的话,变量将可以括在双引号内,并且这些变量名可以包含分隔符。(非必填写)
- 遇到文件结束符再次循环?(Recycle on EOF?):是否循环读取 CSV 文件内容,默认为 True,必须填写。因为 CSV Data Set Config 组件一次读入一行,分割后存入若干变量中交给一个线程组,如果线程数超过文本的记录行数,那么可以选择从头再次读入。
- 为 True 时,当已读取完参数文件内的测试用例数据,还需继续获取用例数据时,此时会循环读取参数文件数据(即:读取文件到结尾时,再重头读取文件)。
- 为 False 时,若已至文件末尾,则不再继续读取测试数据;通常在"线程组的线程数"或者"线程组的循环次数">参数文件组数时,选用 False(即:读取文件到结尾时,停止读取文件)。
- 遇到文件结束符停止线程?(Stop thread on EOF?):如果线程数超过了数据文件中的变量,是否停止,默认为 False。当 Recycle on EOF 为 True 时,此项无意义。
- 线程共享模式(Sharing mode):共享模式,即参数文件的作用域。如果希望每个线程拥有自己独立的值集合,那么就需要创建一系列数据文件,为每个线程准备一个数据文件,如
test1.csv、test2.csv等,使用文件的方式test${__threadNum}.csv,并将 Sharing mode 设置为 Current thread。- 所有线程 All threads(默认):文件在所有线程间共享。即当前测试计划中的所有线程组中的所有的线程都有效。
- 当前线程组 Current thread group:每个文件会针对每个线程组打开一次。即:对当前线程组中的线程有效。
- 当前线程 Current thread:每个文件会针对每个线程单独打开。即:对当前线程有效。
动态参数的使用
在使用的地方直接引用即可:${loginToken}

使用函数助手方式
打开 JMeter,点击"参数设置"按钮。

直接把函数贴到参数设置里。

PostProcessor(在后续接口中用到之前接口保存下来的值)
很多接口都会在 headers 中带着 token 和 clientId(即经过登录接口后返回的 userID)。所以我们需要在登录之后拿到 token 和 userID 的值。
查看返回结果,结果为 JSON 格式。如下内容:
1 | { |
因此我们在登录脚本中增加后置处理器:Beanshell PostProcessor。

录入如下内容:
1 | import net.sf.json.JSONObject; // 导入 JSON 解析用到的 jar 包 |

因在登录后的接口都会在 headers 中带着 token 和 clientId,所以我们需要在这些请求下增加"HTTP 信息头管理器",并将参数添加进去即可。

参数公共化
声明周期为 session 级别,JMeter 关了之后参数将自动销毁**(在后续线程组中用到之前保存下来的值)**。
示例为登录后取出 response header 中的 cookie,然后进行参数公共化,转化为全局变量。
更改 JMeter 的配置文件 jmeter.properties
1 | CookieManager.save.cookies=false |

注意改完以后要把前面的 # 给去掉,重启 JMeter。
登录接口获取到的 response

添加正则表达式提取器,提取两个 cookie 值,括号内部为需要取出的值

- Names of created variables:保存的变量名,后面使用
${SOPEIID}引用 - 正则表达式
- 模板:
$1$为取第一个,$1$$2$为取第一个和第二个,以此类推 - Match No.(0 for Random):匹配数字(0 代表随机,1 代表第一个,-1 代表所有)
- Default Values:找不到时默认值
添加参数,以空格分隔

添加 Beanshell 后置处理器,并使用 __setProperty
1 | // 取第一个参数 |
后续使用 ${__P(newCookie,)} 来获取该全局变量 newCookie 的值。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 小五的个人杂货铺!