使用csv方式

添加->配置元件->CSV Data Set Config添加动态参数。如下:

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

1
2
3
4
5
loginToken
111
2222
3333
4444

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。如果一行数据分隔后的所获得的变量数,比Vairable Names中定义的变量少,这些变量将保留以前的值(如果有值的话),必须填写。
是否允许带引号?(Allow quoted data?):是否允许变量使用双引号,允许的话,变量将可以括在双引号内,并且这些变量名可以包含分隔符。(非必填写)
遇到文件结束符再次循环?(Recycle on EOF?):是否循环读取CSV文件内容,默认为 True,必须填写。
因为CSV Data Set Config组件一次读入一行,分割后存入若干变量中交给一个线程组,如果线程数超过文本的记录行数,那么可以选择从头再次读入;
1)为True时,当已读取完参数文件内的测试用例数据,还需继续获取用例数据时,此时会循环读取参数文件数据(即:读取文件到结尾时,再重头读取文件);
2)为False时,若已至文件末尾,则不再继续读取测试数据;通常在“线程组的线程数“或者”线程组的循环次数“>参数文件组数时,选用False(即:读取文件到结尾时,停止读取文件);
遇到文件结束符停止线程?(Stop thread on EOF?):如果线程数超过了数据文件中的变量,是否停止,默认为 False。当Recycle on EOF为True时,此项无意义。
线程共享模式(Sharing mode):共享模式,即参数文件的作用域。如果希望每个线程拥有自己独立的值集合,那么就需要创建一系列数据文件,为每个线程准备一个数据文件,如test1.csv、test2.csv等,使用文件的方式test${__threadNum}.csv,并将Sharing mode设置为Current thread。
1)所有线程All threads(默认):文件在所有线程间共享。即当前测试计划中的所有线程组中的所有的线程都有效。
2)当前线程组Current thread group:每个文件会针对每个线程组打开一次。即:对当前线程组中的线程有效。
3)当前线程Current thread:每个文件会针对每个线程单独打开。即:对当前线程有效。

动态参数的使用。

在使用的地方直接引用即可:${loginToken}

使用函数助手方式

1.打开Jmeter,点击“参数设置”按钮。

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

PostProcessor(在后续接口中用到之前接口保存下来的值)

很多接口都会在headers中带着token和clentId(即经过登录接口后返回的userID)。所以我们需要在登录之后拿到token和userID的值。

查看返回结果,结果为json格式。如下内容。

1
2
3
4
5
6
7
8
9
{
"message": "登录成功",
"result": {
"userId": "171",
……
},
"returnCode": 200,
"token": "b15f18b0e424eb3f603eba9166f38f65c25652808d4d4b6bb1bfaec8c04fe1ae"
}

因此我们在登录脚本中增加后置处理器:bean shell postprocessor。

录入如下内容。

1
2
3
4
5
6
7
8
9
10
import net.sf.json.JSONObject; //**导入**json**解析用到的**jar**包*

String input = prev.getResponseDataAsString();
JSONObject jsonObject = JSONObject.fromObject(input);
JSONObject result = jsonObject.getJSONObject("result");
String userid = result.getString("userId");
String token = jsonObject.getString("token");
//**把获取到的字符串,赋值给对应的变量。后续的请求中,就可以通过* *${userid}**这样的方式,读取到这个值了。*
vars.put("userid",userid);
vars.put("token",token);

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

参数公共化, 声明周期为session级别, jmeter关了之后参数将自动销毁(在后续线程组中用到之前保存下来的值)

示例为登陆后取出response header中的cookie, 然后进行参数公共化, 转化为全局变量

更改jmeter的配置文件jmeter.properties:

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
2
3
4
5
6
// 取第一个参数
String SOPEIID = bsh.args[0];
// 取第二个参数
String SOPEIID_SIG = bsh.args[1];
//提取cookie拼接两个参数作为公共变量
${__setProperty(newCookie,SOPEIID=${SOPEIID}; SOPEIID.sig=${SOPEIID_SIG},)};

后续使用${__P(newCookie,)} 来获取该全局变量newCookie的值