引用函数表达式
用户在编辑设计组合应用时,可以通过引用函数表达式的方式快速配置连接器的配置信息,帮助用户便捷高效的设计组合应用。
组合应用中的函数表达式使用方法如图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。 | 
 
   
    
