引用函数表达式
用户在编辑设计组合应用时,可以通过引用函数表达式的方式快速配置连接器的配置信息,帮助用户便捷高效的设计组合应用。
组合应用中的函数表达式使用方法如图1所示。
函数表达式的分类
组合应用提供数学、字符串、加解密、日期和时间、编解码、进制转换共六种类型的函数表达式。
分类 |
函数表达式 |
说明 |
---|---|---|
数学(2个) |
sum(array arr) |
返回数组中所有数字的和。例:${sum(3,5,6)},返回14。 |
avg(array arr) |
返回数组中所有数字的平均值。例:${avg(2,4)},返回3。 |
|
字符串(29个) |
uuid() |
生成由字母和数字组成的随机uuid。 |
upper(string str) |
将字符串全部转换为大写字符。例:${upper('abc')},返回“ABC”。 |
|
lower(string str) |
将字符串全部转换为小写字符。例:${lower('ABC')},返回“abc”。 |
|
camelize(string str) |
使用驼峰式大小写转换str中的单词,删除所有空格,并将除第一个单词外的每个单词的首字母转换为大写。例:${camelize('aaa_bbb_ccc')},返回“aaaBbbCcc”。 |
|
dasherize(string str) |
使用kebab-case转换str中的单词,将str中的所有字母转换为小写,将所有空格转换为连字符(-)。例:${dasherize('Aaa Bbb Ccc')},返回“aaa-bbb-ccc”。 |
|
capitalize(string str) |
使用大小写转换str中的单词,将每个单词的第一个字母变为大写,其余字母变为小写。例:${capitalize('aaaBbbCcc')},返回“Aaa Bbb Ccc”。 |
|
charCode(string char) |
将char转换为字符编码。例:${charCode('hello')},返回104。 |
|
fromCharCode(number charCode) |
将字符编码转换为字符串。例:${fromCharCode(104)},返回“h”。 |
|
charCodeAt(string str, number index) |
返回str中索引处的字符编码。例:${charCodeAt('hello', 2)},返回108。 |
|
isAlpha(string str) |
返回一个布尔值,确定提供的字符串是否只包含英文字母。例:${isAlpha('abc'),返回true; ${isAlpha('a-b-c')},返回false。 |
|
isAlphanumeric(string str) |
返回一个布尔值,确定提供的字符串是否只包含英文字母或数字。例:${isAlphanumeric('aBc123')},返回true;${isAlphanumeric('aBc-123')},返回false。 |
|
isNumeric(string str) |
返回一个布尔值,确定提供的字符串是否只包含数字。例:${isNumeric('123')},返回true;${isNumeric('1-2-3')},返回false。 |
|
isLowerCase(string str) |
返回一个布尔值,确定str是否全部为小写。例:${isLowerCase('abc')},返回true;${isLowerCase('aBc')},返回false。 |
|
isUpperCase(string str) |
返回一个布尔值,确定str是否全大写。例:${isUpperCase('ABC')},返回true;${isUpperCase('AbC')},返回false。 |
|
isWhitespace(string str) |
返回一个布尔值,确定str是否只包含空格。例:${isWhitespace(' ')},返回true,${isWhitespace('a b c')},返回false。 |
|
leftPad(string str, number offset) |
如果字符串小于偏移长度,则用空格填充str的左侧。例:${leftPad('abc', 4)},返回“ abc”。 |
|
rightPad(string str, number offset) |
如果字符串小于偏移量长度,则用空格补全str的右侧。例:${rightPad('abc', 4)},返回“abc ”。 |
|
substringAfter(string str, string separator) |
获取str在第一次出现分隔符之后的子字符串。例:${substringAfter('a,b,c,d', ',')},返回“b,c,d”。 |
|
substringAfterLast(string str, string separator) |
获取str中分隔符最后一次出现之后的子字符串。例:${substringAfterLast('a,b,c,d', ',')},返回“d”。 |
|
substringBefore(string str, string separator) |
获取str中第一次出现分隔符之前的子字符串。例:${substringBefore('a,b,c,d', ',')},返回“a”。 |
|
substringBeforeLast(string str, string separator) |
获取str中分隔符最后出现之前的子字符串。例:${substringBeforeLast('a,b,c,d', ',')},返回“a,b,c”。 |
|
unwrap(string str, string wrapper) |
返回没有包装器文本的str。包装器文本是str前面和/或后面的值。例:${unwrap("/test/", "/")},返回 “test”。 |
|
withMaxSize(string str, number size) |
限制str的大小。例:${withMaxSize('abcd', 3)},返回“abc”。 |
|
wrapIfMissing(string str, string wrapper) |
如果str没有被包装,则将包装器添加到str的前面和末尾。如果包装器在开始或结束时已经存在,则只更新缺失端。例:${wrapIfMissing("/test", "/")},返回“/test/”。 |
|
wrapWith(string str, string wrapper) |
将包装器添加到str的前面和后面。例:${wrapWith("test", "/")},返回“/test/”。 |
|
ordinalize(number num) |
将num转换为有序字符串格式,例如1st, 2nd, 3rd等。例:${ordinalize(3)},返回 3rd。 |
|
appendIfMissing(string str, string value) |
如果str不以value结尾,则在str后面加上value。例:${appendIfMissing('ab', 'cd')},返回“abcd”。 |
|
prependIfMissing(string str, string value) |
如果str不以value开头,则在str前面加上value。例:${prependIfMissing('cd', 'ab')},返回“abcd”。 |
|
repeat(string str, number times) |
重复给定的次数。例:${repeat('abc', 3)},返回“abcabcabc”。 |
|
加解密(4个) |
hash(string value, string algorithm) |
使用支持的算法计算value的散列值。算法必须是MD2、MD5、SHA-1、SHA-256、SHA-384、SHA-512中的一种。例:${hash('abcd', 'MD5')},返回“e2fc714c4727ee9395f324cd2e7f331f”。 |
hmac(string value, string secret, string algorithm) |
使用提供的值、密钥和散列函数算法生成基于散列的消息验证码。必须是HmacSHA1、HmacSHA256或HmacSHA512中的一种。例:${hmac('abcd', 'test', 'HmacSHA1')},返回“bcde772eafae465fe002b2bbb5c68d66da0d241a”。 |
|
encrypt(string value, string secret, string transformation) |
使用指定的JDK和提供的密钥对值进行加密。使用Base64将加密转换为可读的格式。例:${encrypt('Hello', '8byteKey', 'DES/CBC/PKCS5Padding')},返回“Ic3THvsowTV3itOf40K56w==”。 |
|
decrypt(string value, string secret, string algorithm, string mode, string padding) |
使用指定的JDK和提供的密钥解密Base64值。例:${decrypt("Ic3THvsowTV3itOf40K56w==", "8byteKey", "DES/CBC/PKCS5Padding")},返回“Hello”。 |
|
日期和时间(20个) |
now() |
返回当前的日期时间。例:${now()},返回“2025-03-26T03:17:37”。 |
compare(string datetime1, string datetime2) |
如果datetime1 > datetime2返回1,如果datetime1 < datetime2返回-1,如果datetime1 == datetime2返回0。例:${compare('2025-03-26T05:20:30Z', '2025-03-27T05:20:30Z')},返回 -1。 |
|
atBeginningOfDay(string datetime) |
返回给定时间的午夜时间值。例:${atBeginningOfDay('2025-03-26T05:20:30Z')},返回“2025-03-26T00:00:00Z”。 |
|
atBeginningOfHour(string datetime) |
返回给定的日期时间,分钟数和秒数设置为0。例:${atBeginningOfHour('2025-03-26T05:20:30Z')},返回“2025-03-26T05:00:00Z”。 |
|
atBeginningOfMonth(string datetime) |
返回给定的日期时间,日期设置为月份的第一天,时间设置为午夜。 例:${atBeginningOfMonth('2025-03-26T05:20:30Z')},返回“2025-03-01T00:00:00Z”。 |
|
atBeginningOfWeek(string datetime) |
返回当前星期第一天的给定的日期时间,并将时间设置为午夜。例:${atBeginningOfWeek('2025-03-26T05:20:30Z')},返回“2025-03-23T00:00:00Z”。 |
|
atBeginningOfYear(string datetime) |
返回一年中的第一个给定的日期时间,并将时间设置为午夜。例:${atBeginningOfYear('2025-03-26T05:20:30Z')},返回“2025-01-01T00:00:00Z”。 |
|
changeTimeZone(string datetime, string timezone) |
更改日期时区,这通常会导致本地日期时间的更改。例:${changeTimeZone('2024-05-22T08:25:16Z', 'UTC')},返回“2024-05-22T08:25:16Z”。 |
|
daysBetween(string datetime1, string datetime2) |
返回datetime1和datetime2之间的天数。例:${daysBetween('2024-05-22T08:25:16Z', '2024-05-28T18:25:16Z')},返回6。 |
|
format(string datetime, string outputFormat) |
给定一个datetime,将其转换为指定的输出格式。例:${format('2024-05-22T08:25:16Z', 'yyyy/MM/dd HH:mm')},返回“2024/05/22 08:25”。 |
|
isLeapYear(string datetime) |
返回一个布尔值,表示datetime是否为闰年。例:${isLeapYear('2024-05-22T08:25:16Z')},返回 true。 |
|
plus(string datetime, string period) |
按照给定的类型为datetime添加日期。例:${plus('2024-05-22T08:25:16Z', 'P1D')},返回“2024-05-23T08:25:16Z”。 |
|
minus(string datetime, string period) |
按照给定的类型为datetime减去日期。例:${minus('2024-05-22T08:25:16Z', 'P1D')},返回“2024-05-21T08:25:16Z”。 |
|
parse(string|number datetime, string inputFormat) |
使用输入格式解析datetime,并以默认格式返回值。如果使用epoch或timestamp值作为datetime,则可以使用"epoch"或"timestamp"作为inputFormat。例:${parse('12/31/1990 10:10:10', 'MM/dd/yyyy HH:mm:ss')},返回“1990-12-31T10:10:10Z”。 |
|
toLocalDate(string datetime) |
将日期转换为本地日期。例:${toLocalDate('2024-05-22T08:25:16Z')},返回“2024-05-22”。 |
|
toLocalDateTime(string datetime) |
将日期时间转换为本地日期时间。例:${toLocalDateTime('2024-05-22T08:25:16Z')},返回“2024-05-22T08:25:16”。 |
|
toLocalTime(string datetime, string format) |
将时间转换为本地时间。例:${toLocalTime('2024-05-22T08:25:16Z')},返回“08:25:16”。 |
|
today() |
返回当天午夜的时间。 |
|
tomorrow() |
返回第二天午夜的时间。 |
|
yesterday() |
返回前一天午夜的时间。 |
|
编解码(2个) |
encode(string data, string encoding="UTF-8") |
使用提供的编码方案将字符串转换为application/x-www-form-urlencoded格式,以获取不安全的字节。默认编码为UTF-8。例:${encode('Hello,世界', encoding="UTF-8")},返回“Hello%EF%BC%8C%E4%B8%96%E7%95%8C”。 |
decode(string data, string encoding="UTF-8") |
使用特定的编码方案解码application/x-www-form-urlencoded字符串。所提供的编码用于确定以“%xy”形式的任意连续序列表示哪些字符。例:${decode('Hello%EF%BC%8C%E4%B8%96%E7%95%8C', encoding="UTF-8")},返回“Hello,世界”。 |
|
进制转换(9个) |
fromBase64(string value) |
将base64转换为值。例:${fromBase64('SGVsbG8=')},返回“Hello”。 |
toBase64(any value) |
将value转换为base64。当前不支持直接传入数组以及类似${083xxx|param}格式的payload关键字;数组格式需要添加单引号,如下图: 例:${toBase64('Hello')},返回“SGVsbG8=”。 |
|
fromHex(string value) |
将十六进制转换为值。例:${fromHex(13)},返回19。 |
|
toHex(any value) |
将value转换为十六进制。例:${toHex(19)},返回13。 |
|
fromBinary(number value) |
将值从二进制转换为十进制。例:${fromBinary(101)},返回5。 |
|
fromHex(number value) |
将值从十六进制转换为十进制。例:${fromHex(13)},返回19。 |
|
fromRadixNumber(number value, number baseAsBinary) |
将输入值转换通过指定的进制转换为十进制。例:${fromRadixNumber(101, 2)},返回5。 |
|
toBinary(number value) |
将值从十进制转换为二进制。例:${toBinary(8)},返回 1000。 |
|
toRadixNumber(number value, number baseAsDecimal) |
将值转换为指定的进制。例:${toRadixNumber(5, 2)},返回101。 |