·JMeter提供了很多函数,如果能够熟练使用,可以为脚本带来很多方便。

·JMeter函数是一种特殊值,可用于除测试计划外的任何组件。

·函数调用的格式如下所示:

  ${__functionName(var1,var2,var3)}

  其中,__functionName为函数名,括号内是函数的参数,无参数时可以不用括号,如${__UUID}

·Tips:

  如果参数包含逗号,那么一定要使用“\”来转义,否则JMeter会把它当作一个参数分隔符

  实际使用时,可通过函数助手对话框选择函数,设置参数后,点击生成按钮生成函数字符串。

  一、__BeanShell:beanshell函数

 1、它有两个参数,第一个参数是要执行的语句,可以是beanshell语句或者是文件地址,是必选参数;第二个参数是保存结果的变量名称,非必选参数。

  2、Example:

  ${__BeanShell(123*456)}:返回56088

  ${__BeanShell(source("function.bsh"))}:会执行外部脚本function.bsh,并返回结果
  ${__BeanShell(importjava.util.*;Propertiesprops=System.getProperties();StringosName=props.getProperty("os.name");if(osName.contains("Windows")) return443;return8443;)}:判断端口

  3、与beanshell元件比较:

  该函数与beanshell元件(beanshellsampler、beanshellpreprocess等)作用是一样的,只是beanshell函数更常用于一些简单的判断或计算等,可以把少量的脚本放在函数中直接赋值给一个变量,而不用总是添加beanshell元件。

  二、__regexFunction:正则表达式函数

1、该函数使用用户提供的正则表达式来解析前面的服务器响应(或者是某个变量值)。函数会返回一个有模板的字符串,其中携带有可变的值。

  2、__regexFunction还可以被用来保存值,以便供后续使用。在函数的第6个参数中,测试人员可以指定一个引用名。在函数执行以后,测试人员可以使用用户定义值的语法来获取同样的值。例如,如果测试人员输入"refName"作为第6个参数,那么测试人员可以使用:

  ${refName}来引用第2个参数(Templateforthereplacementstring)的计算结果,这依赖于函数的解析结果。

  ${refName_g0}来引用函数解析后发现的所有匹配结果。

  ${refName_g1}来引用函数解析后发现的第一个匹配组合。

  ${refName_g#}来引用函数解析后发现的第n个匹配组合。

  ${refName_matchNr}来引用函数总共发现的匹配组合数目。

其实这个函数的作用跟正则表达式提取器的作用是类似的。

  三、__counter:计数器函数

1、每次调用计数器函数都会产生一个新值,从1开始每次加1。计数器既可以被配置成针对每个虚拟用户是独立的,也可以被配置成所有虚拟用户公用的。

  2、如果每个虚拟用户的计数器是独立增长的,那么通常被用于记录测试计划运行了多少遍。全局计数器通常被用于记录发送了多少次请求。

  3、计数器使用一个整数值来记录,允许的最大值为2,147,483,647。

  4、目前计数器函数实例是独立实现的(JMeter2.1.1及其以前版本,使用一个固定的线程变量来跟踪每个用户的计数器,因此多个计数器函数会操作同一个值)。全局计数器(FALSE)每个计数器实例都是独立维护的。

  5、该函数也有对应的配置元件:计数器,功能类似。

  四、__threadNum

  函数__threadNum只是简单地返回当前线程的编号。线程编号不依赖于线程组,这就意味着从函数的角度看来,某个线程组的线程#1和另一个线程组的线程#1是没有区别的。另外,该函数没有参数。

  这一函数不能用在任何配置元件中(如用户定义的变量),原因在于配置元件是由一个独立线程运行的。另外在测试计划(TestPlan)中使用也是没有意义的。所以,很少用。

  五、__intSum:整数求和函数

  1、函数__intSum可以被用来计算两个或者更多整数值的合。至少需要两个整数,如果指定变量名则名称中必须包含一个非数字字母,否则它会被当成另一个整数值,而被函数用于计算。

  2、当有多个整数时点击添加按钮来增加参数,但是需要注意的是,添加完参数后,点击”生成”的函数默认是把手动添加的函数放在后面,这时需要手动调整变量名的位置,把它放到最后,否则会报错。


六、__longSum:长整型求和函数

  该函数用来计算两个或更多长整型值的和,使用方法跟上面的__intSum函数一样。

  七、__StringFromFile:读取文件中的字符串函数

 1、该函数用来从文本文件中读取字符串。支持读取多个文件。

  2、使用配置元件CSVDataSetConfig,也能达到相同的目的,而且方法更简单,但是它目前不支持多个输入文件。

  3、每次调用函数,都会从文件中读取下一行。当到达文件末尾时,函数又会从文件开始处重新读取,直到最大循环次数。如果在一个测试脚本中对该函数有多次引用,那么每一次引用都会独立打开文件,即使文件名是相同的(如果函数读取的值,在脚本其他地方也有使用,那么就需要为每一次函数调用指定不同的变量名)。

  4、如果在打开或者读取文件时发生错误,那么函数就会返回字符串"**ERR**"。

  示例:

  ${_StringFromFile(demo.txt,,,)}读取demo.txt

  ${_StringFromFile(PIN#'.'DAT,,1,2)}读取demo1.txt,demo2.txt

  ${_StringFromFile(PIN.DAT,,,2)}读取demo.txt两次

  5、函数的第三个参数:初始的序列号,如果省略,那么结束序列号就代表文件的循环读取次数。

  6、函数的第四个参数:结束序列号,如果省略,那么序列号会无限增长。

  7、读取多个文件示例:

  需要在文件名中使用序列号:当使用序列号时,文件名需要使用格式字符串java.text.DecimalFormat。当前的序列号会作为唯一的参数。如果不指明可选的初始序列号,就使用文件名作为起始值。一些有用的格式序列如下:

  #:插入数字,不从零开始,不包含空格。

  000:插入数字,包含3个数字组合,不从零开始。

  例如:

  pin#'.'dat->pin1.dat,...pin9.dat,pin10.dat,...pin9999.dat

  pin000'.'dat->pin001.dat...pin099.dat...pin999.dat...pin9999.dat

  pin'.'dat#->pin.dat1,...pin.dat9...pin.dat999

  如果不希望某个格式字符被翻译,需要为它加上单引号。注意上面的"."是格式字符,必须被单引号所包含。

  比如现在要同时读取两个文件,分别是PIN1.DAT,PIN2.DAT:

  ${_StringFromFile(PIN#'.'DAT,,1,2)}:同时读取PIN1.DAT,PIN2.DAT。

  ${_StringFromFile(PIN.DAT,,,2)}:读取PIN.DAT两次。

  ${_StringFromFile(test#'.'txt,,1,2)}:同时读取test1.txt,test2.txt

  八、__machineName

  函数__machineName返回本机的主机名。

  九、__javaScript

  1、函数__javaScript可以用来执行JavaScript代码片段(非Java),并返回结果值。

  2、JMeter的_javaScript函数会调用标准的JavaScript解释器,还可以直接调用jmeter的内置函数。

  3、请记得为文本字符串添加必要的引号。另外,如果表达式中有逗号,请确保对其转义。例如,${__javaScript('${sp}'.slice(7\,99999))},对7之后的逗号进行了转义。

  十、__Random:随机数函数

  函数__Random会返回指定最大值和最小值之间的随机数。

  十一、_RandomString():随机字符串函数

  1、Randomstringlength:随机字符的长度

  2、Charstouseforrandomstringgeneration:用来生成随机字符串的字符,可以是纯数字,纯字符,字符字母数字组合

  3、Nameofvariableinwhichtostoretheresult(optional):随机生成的字符被变量保存

  4、${__RandomString(6,abcdefgh1234566,ranstr)},解释:随机生成一个6位长度的字符串被ranstr保存;

  十二、__property

  1、函数__property会返回一个JMeter属性的值。如果函数找不到属性值,而又没有提供默认值,则它会返回属性的名称。

  2、例如,

  ${__property(user.dir)}:返回属性user.dir的值。

  ${__property(user.dir,UDIR)}:返回属性user.dir的值,并保存在变量UDIR中。

  ${__property(abcd,ABCD,atod)}:返回属性abcd的值(如果属性没有定义,返回"atod"),并保存在变量ABCD中。

  ${__property(abcd,,atod)}:返回属性abcd的值(如果属性没有定义,返回"atod"),但是并不保存函数的返回值。

  十三、_P

  1、函数_P是一个简化版的属性函数,目的是使用在命令行中定义的属性。

  2、不同于函数_property,本函数没有提供选项用于设置保存属性值的变量。另外,如果没有设置默认值,默认值自动设为1。

  3、例如:定义属性值:

  jmeter-Jgroup1.threads=7-Jhostname1=http://www.realhost.edu

  获取值如下:

  ${__P(group1.threads)}:返回属性group1.threads的值。

  ${__P(group1.loops)}:返回属性group1.loops的值。

  ${__P(hostname,http://www.baidu.com)}:返回属性hostname的值,如果没有定义该属性则返回值http://www.baidu.com

  在上面的例子中,第一个函数调用返回7,第二个函数调用返回1,而最后一个函数调用返回http://www.baidu.com(除非这些属性在其他地方有定义)。

  十四、__log

  1、函数__log会记录一条日志,并返回函数的输入字符串。

  2、OUT和ERR的日志级别,将会分别导致输出记录到System.out和System.err中。在这种情况下,输出总是会被打印(它不依赖于当前的日志设置)。

  例如:

  ${__log(Message)}:写入日志文件,形如"...threadName:Message"。

  ${__log(Message,OUT)}:写到控制台窗口。

  ${__log(${VAR},,,VAR=)}:写入日志文件,形如"...threadNameVAR=value"。

  十五、__split:字符串分割函数

  1、函数__split会通过分隔符来拆分传递给它的字符串,并返回原始的字符串。如果分隔符紧挨在一起,那么函数就会以变量值的形式返回"?"。拆分出来的字符串,以变量${VAR_1}、{VAR_2}…以此类推的形式加以返回。

  2、分隔符默认是逗号,如果你想要多此一举,明确指定使用逗号,需要对逗号转义,如“\,”

  3、例如,在测试计划中定义变量VAR="a||c|":

  ${__split(${VAR},VAR),|}:该函数调用会返回VAR变量的值,例如"a||c|",并设定VAR_n=4、VAR_1=a、VAR_2=?、VAR_3=c、VAR_4=?、VAR_5=null变量的值。

  十六、__XPath

  1、函数__XPath读取XML文件,并在文件中寻找与指定XPath相匹配的地方。每调用函数一次,就会返回下一个匹配项。到达文件末尾后,会从头开始。如果没有匹配的节点,那么函数会返回空字符串,另外,还会向JMeter日志文件写一条警告信息。

  整个节点列表都会被保存在内存之中。

  例如:

  ${__XPath(/path/to/build.xml,//target/@name)}

  这会找到build.xml文件中的所有目标节点,并返回下一个name属性的内容。

  十七、__setProperty

  1、函数__setProperty用于设置JMeter属性的值。函数的默认返回值是空字符串,因此该函数可以被用在任何地方,只要对函数本身调用是正确的。

  2、通过将函数可选的第3个参数设置为"true",函数就会返回属性的原始值。

  3、属性对于JMeter是全局的,因此可以被用来在线程和线程组之间通信。

  十八、__time

  1、函数__time可以通过多种格式返回当前时间。

  2、如果省略了格式字符串,那么函数会以毫秒的形式返回当前时间。其他情况下,当前时间会被转成简单日期格式。包含如下形式:

  YMD=yyyyMMdd。

  HMS=HHmmss。

  YMDHMS=yyyyMMdd-HHmmss。

  USER1=JMeter属性time.USER1。

  USER2=JMeter属性time.USER2。

  用户可以通过修改JMeter属性文件来改变默认格式,或者自定义格式,例如修改YMD格式:time.YMD=yyMMdd。

  十九、__V

  1、函数__V可以用于执行变量名表达式,并返回执行结果。它可以被用于执行嵌套函数引用(目前JMeter不支持)。

  2、例如,如果存在变量A1、A2和N=1,则:

  ${A1}:能正常工作。

  ${A${N}}:无法正常工作(嵌套变量引用)。

  ${__V(A${N})}:可以正常工作。A${N}变为A1,函数__V返回变量值A1。

  二十、__evalVar

  1、函数__evalVar可以用来执行保存在变量中的表达式,并返回执行结果。

  如此一来,用户可以从文件中读取一行字符串,并处理字符串中引用的变量。

  2、例如,假设变量"query"中包含有"select${column}from${table}",而"column"和"table"中分别包含有"name"和"customers",那么${__evalVar(query)}将会执行"selectnamefromcustomers"。

  二十一、__eval

  1、函数__eval可以用来执行一个字符串表达式,并返回执行结果。

  如此一来,用户就可以对字符串(存储在变量中)中的变量和函数引用做出修改。

  2、例如,给定变量name=Smith、column=age、table=birthdays、SQL=select${column}from${table}wherename='${name}',那么通过${__eval(${SQL})},就能执行"selectagefrombirthdayswherename='Smith'"。这样一来,就可以与CSV数据集相互配合,例如,将SQL语句和值都定义在数据文件中。

  二十二、__escapeHtml

  1、函数__escapeHtml用于转义字符串中的字符(使用HTML实体)。支持HTML4.0实体。

  二十三、__unescapeHtml

  1、函数__unescapeHtml用于反转义一个包含HTML实体的字符串,将其变为包含实际Unicode字符的字符串。支持HTML4.0实体。

  2、如果函数不认识某个实体,就会将实体保留下来,并一字不差地插入结果字符串中。例如,">&zzzz;x"会变为">&zzzz;x"。

  二十四、__FileToString

  1、函数__FileToString可以被用来读取整个文件。每次对该函数的调用,都会读取整个文件。

  2、如果在打开或者读取文件时发生错误,那么函数就会返回字符串"**ERR**"。