官方文档
__BeanShell
- 入参:BeanShell语法的程序语句或者Bean Shell脚本文件
- 示例:
${__BeanShell(123*456,)}:返回56088;
${__BeanShell(source("function.bsh",))}:执行在function.bsh中的脚本;
__changeCase
- 作用:修改字符串大小写
- 入参:字符串
- 示例:
${__changeCase(test,UPPER,upper_test)}
__char
- 作用:把一组数字转化成Unicode字符
- 入参:数字
- 示例:
${__char(65,66)},变成AB
__counter
- 作用:作为一个计数器使用,支持多线程(多用户)
- 入参:计数变量i,是否为线程计数器True/False
- 示例
${__counter(FALSE,i)}; 全局计数器
${__counter(TRUE,i)}; 每个用户有自己的计数器
__CSVRead
- 作用:从文件读取指定列的值(读取固定值/读取动态值/使用文件别名)
- 入参:文件路径;读取方式;
- 示例
${__CSVRead(E:\user_info.csv,0)};读取第一列的值
${__CSVRead(E:\user_info.csv,next())}; 每次读取下一次的值,配合第一条使用,否则不知道从哪里开始
${__CSVRead(E:\user_info.csv,*user_info)};使用别名,然后通过以下方法获取数据
${__CSVRead(*user_info, 1)}
__dataTimeConvert
- 作用:格式化日期
- 入参:日期/时间
- 示例:
${__dateTimeConvert(01212018,MMddyyyy,dd/MM/yyyy,)}
${__dateTimeConvert(1526574881000,,dd/MM/yyyy HH:mm,)}; 官方例子,但是本地没试出来
__digest
- 作用:加密
- 入参:
- 加密算法:MD2, MD5, SHA-1, SHA224, SHA256, SHA384, SHA512
- 需要加密的值
- 撒盐加密
- 是否要转成大写
- 变量名称
关于撒盐加密(salt)
使用salt加密,它的基本想法是这样的:
1.用户注册时,在密码上撒一些盐。生成一种味道,记住味道。
2.用户再次登陆时,在输入的密码上撒盐,闻一闻,判断是否和原来的味道相同,相同就让你吃饭。
- 示例:
${__digest(MD5,test,1,,)}
__escapeHtml
- 作用:字符转成Html格式的字符,这样编码后传给浏览器,浏览器就能识别了
- 入参:字符
- 示例:
${__escapeHtml(")}
__escapeOroRegexChars
- 作用:把正则表达式转换成Java正则引擎能识别的表达式
- 入参:正则表达式
- 示例:
${__escapeOroRegexpChars([^"].+?,test)}
__escapeXml
- 作用:字符转成xml格式的字符
- 入参:字符
- 示例:
${__escapeXml("bread" & 'butter')}
__eval
- 作用:返回一个表达式的值,可以用此函数表达式来嵌套引用表达式
- 入参:字符
- 示例:
name=Smith
column=age
table=birthdays
SQL=select ${column} from ${table} where name='${name}'
${__eval(${SQL})}; 引用SQL变量
__evalVar
- 作用:返回一个表达式的结果,存到一个变量中,供使用
- 入参:字符
- 示例:
QUERY = select ${column} from ${table}; column=name, table=customers
${__evalVar(QUERY)} = select name from customers
__fileToString
- 作用:读取文件保存至变量中
- 入参:文件路径;编码格式;变量名
- 示例:
${__FileToString(E:\user_info.csv,utf-8,user_info)}
__groovy
- 作用:执行Apache Groovy脚本,并返回结果
- 入参:表达式;变量名
- 示例:
${__groovy(123*456,test)}
__intSum
- 作用:整数求和,多个数字之间用逗号分隔
- 入参:第一个整数;第二个及之后的整数;变量名
- 示例:
${__intSum(1,2,3,4,5,6,7,8,test)}
__isPropDefined
- 作用:判断属性是否存在
- 入参:属性名称
- 示例:
${__isPropDefined(START.HMS)}
__isVarDefined
- 作用:判断变量是否存在
- 入参:变量名称
- 示例:
${__isVarDefined(JMeterThread.last_sample_ok)}
__javaScript
- 作用:返回js脚本执行结果
- 入参:js表达式;变量名
- 示例:
${__javaScript(new Date(),date)}
__jexl2
- 作用:返回jexl表达式执行结果,使用JEXL2
- 入参:jexl表达式;变量名
- 示例:
${__jexl2(vars.get("START.YMD"),test)}
__jexl3
- 作用:返回jexl表达式执行结果,JEXL3
- 入参:jexl表达式;变量名
- 示例:
${__jexl3(vars.get("START.YMD"),test)}
__log
- 作用:日志方法,返回输入的字符串信息
- 入参:字符串;日志级别;抛出的异常信息;附加信息
- OUT:控制台打印
- ERR:控制台输出,同时打印到标准输出
- DEBUG:控制台输出,DEBUG级别以上的都打印
- INFO:控制台打印INFO及ERROR级别的日志
- WARN:控制台打印WARN,INFO,ERROR级别的日志
- ERROR:控制台打印ERROR级别的日志
- 示例:
${__log(testing,ERR,error throw test,error test)}
__logn
与__log类似,不过它只记录一条日志,不返回值。
${__logn(testing,,)}
__longSum
- 作用:计算长整型的和
- 入参:整数
- 示例:
${__longSum(1,2,3,4,sum)}
__machineIP
- 作用:引用返回本机IP
- 入参:变量名
- 示例:
${__machineIP(ip)}
__machineName
- 作用:引用返回本机Name
- 入参:变量名
- 示例:
${__machineName(name)}
__P
- 作用:获取命令行中定义的属性,非GUI方式运行测试计划时这个函数可用来做参数化,由运行命令动态指定参数值,方便与Jenkins等集成完成性能测试工作
- 入参:属性名称;默认值
- 示例:
${__P(group1.threads,)}
__property
- 作用:获取Jmeter的属性,%JMETER_HOME%\bin\jmeter.properties
- 入参:属性名称;变量名;默认值
- 示例:
${__property(log_level.jmeter,log_Level,)}
__Random
- 作用:生成指定范围内的随机数
- 入参:左右范围;变量名
- 示例:
${__Random(1,20,random_num)}
__RandomDate
- 作用:生成指定范围内的日期
- 入参:日期格式;左右范围;语言;变量名
- 示例:
${__RandomDate(,,2050-07-08,,)}
__RandomFromMultipleVars
- 作用:给定的多个值中随机取值
- 入参:多个值,使用|分隔;变量名
- 示例:
${__RandomFromMultipleVars(a|b|c|d|e,select)}
__RandomString
- 作用:生成指定长度的字符串
- 入参:字符串长度;可选字符串;变量名
- 示例:
${__RandomString(5,a3fxis,random_char)}
__regexFunction
- 作用:提取正则表达式
- 入参:
- 用于解析服务器响应数据的正则表达式
- 模板字符串()
- 告诉JMeter使用第几次匹配
- 整数n:使用第n个匹配项;
- RAND:随机选择一个匹配项;
- ALL:使用所有匹配项,为每个匹配项创建一个模板字符串,并将它们连接在一起
- 浮点值0到1之间:根据公式(找到的总匹配数目*指定浮点值)计算使用第几个匹配项,计算值向最近的整数取整
- 如果在上一个参数中选择了“ALL”,那么这第4个参数会被插入到重复的模板值之间
- 如果没有找到匹配项返回的默认值
- 重用函数解析值的引用名
- 变量名称
- 示例:
${__regexFunction(road(.*)test,$1$,1,,,,)}
__samplerName
- 作用:获取当前按sampler的名称
- 入参:变量名
- 示例:
${__samplerName(sample_name)}
__setProperty
- 作用:动态设置jmeter属性
- 入参:属性名称;属性值;是否返回函数结果
- 示例:
${__setProperty(log_level.jmeter,Debug,true)}
__split
- 作用:拆分字符串
- 入参:待拆分字符串;变量名(使用变量名_x来访问第x个拆分结果);分隔符
- 示例:
${__split(test|is|intresting,para,|)}
__StringFromFile
- 作用:从文件中读取内容,一行一行的读取,读完再从头开始
- 入参:文件全路径,变量名,多文件读取起止
- 示例:
${__StringFromFile(D:\user_info.txt,info,,)}
__TestPlanName
- 作用:获取测试计划名称
- 入参:无
- 示例:
${__TestPlanName}
__threadNum
- 作用:返回当前线程号
- 入参:无
- 示例:
${__threadNum}
__time
- 作用:返回当前时间,可指定返回格式,由SimpleDateFormat类处理函数格式
- 年:yyyy
- 月:MM
- 日:dd
- 时:hh
- 分:mm
- 秒:ss
- 入参:返回格式;变量名
- 示例:
${__time(yyyy-MM-dd hh:mm:ss,)}
__timeShift
- 作用:
- 入参:
- 格式:创建日期的格式。如果该值未被传递,则以毫秒为单位创建日期。
- 日期:日期值
- 移位:从日期参数的值中添加或减去多少天,几小时或几分钟
- “PT20.345S”解析为“20.345秒”
- “PT15M”解析为“15分钟”
- “PT10H”解析为“10小时”
- “P2D”解析为“2天”
- “P2DT3H4M”解析为“2天,3小时和4分钟”
- “P-6H3M”解析为“-6小时+3分钟”
- “-P6H3M”解析为“-6小时-3分钟”
- “-P-6H + 3M”解析为“+6小时和-3分钟”
- 区域设置:设置创建日期的显示语言
- 变量名
- 示例:
${__timeShift(yyyy-MM-dd HH:mm:ss,PT20.345S,,,c)}
__unescape
- 作用:反转escape字符
- 入参:字符
- 示例:
${__unescape(\r\n)}
__unescapeHtml
- 作用:反转URL连接中的Unicode编码字符
- 入参:字符
- 示例:
${__unescapeHtml( )}
__urldecode
- 作用:decode application/x-www-form-urlencoded字符串
- 入参:待decode字符串
- 示例:
${__urldecode(Word+%22school%22+is+%22%C3%A9cole%22+in+french)}
__urlencode
- 作用:与urldecode
- 入参:待encode字符串
- 示例:
${__urlencode(Word "school" is "école" in french)}
__UUID
- 作用:获取UUID
- 入参:无
- 示例:
${__UUID}
__V
- 作用:获取含变量名的表达式
- 入参:含变量名的表达式
- 示例:
${A1} - 可以正确访问
${A${N}} - 无法访问,嵌套变量
${__V(A${N})} - 可以访问。A${N}变成A1,__V函数返回A1的值
__XPath
- 作用:根据xpath获取xml节点内容,没有匹配到,则返回空字符串
- 入参:待解析的xml文件;xpath表达式匹配xml节点
- 示例:
${__XPath(/path/to/build.xml,//target/@name)}
可直接访问变量
- log:直接调用logger函数
- ctx:获取JMeterContent对象
- vars:获取JMeter定义的变量
- props:获取JMeter配置属性
- threadName:获取Jmeter线程名
- sampler:获取Sampler实例
- sampleResult:获取SamplerResult实例
- OUT:类似System.out.println, OUT.println()