產(chǎn)品介紹
什么是數(shù)環(huán)通
基礎(chǔ)概念講解
應(yīng)用場景
多渠道數(shù)據(jù)融合
業(yè)務(wù)、財務(wù)、辦公自動化
產(chǎn)業(yè)鏈應(yīng)用與數(shù)據(jù)集成
工業(yè)應(yīng)用與設(shè)備互聯(lián)
智慧園區(qū)與未來社區(qū)
快速入門
創(chuàng)建LinkUp
應(yīng)用授權(quán)
判斷用法
監(jiān)控用法
分支用法
列表逐條處理
變量與表達(dá)式
流程管理
項目管理
流程創(chuàng)建
編輯器操作
單步測試與預(yù)覽
試運(yùn)行
發(fā)布與版本管理
錯誤步驟重試
數(shù)據(jù)同步
JSON Path 使用
輸出處理
數(shù)據(jù)編排
1、功能使用手冊
2、腳本使用手冊
1 、簡單查詢
2、謂詞查詢
3、函數(shù)與表達(dá)式
4、構(gòu)建結(jié)構(gòu)結(jié)果
5、查詢組合
6、排序、分組和聚合
7、處理模型
8、函數(shù)式編程
9、正則表達(dá)式
10、日期、時間處理
11、路徑運(yùn)算符
12、數(shù)字運(yùn)算符
13、比較運(yùn)算符
14、布爾運(yùn)算符
15、其他運(yùn)算符
16、字符串函數(shù)
17、數(shù)值函數(shù)
18、 數(shù)字聚合函數(shù)
19、布爾函數(shù)
20、數(shù)組函數(shù)
21、對象函數(shù)
22、日期/時間函數(shù)
23、高階函數(shù)
運(yùn)行日志
運(yùn)行記錄
開發(fā)工具
連接器工具
連接器源碼配置
控件類型配置
腳本配置說明
內(nèi)置函數(shù)
應(yīng)用講解
內(nèi)置應(yīng)用
瀏覽器插件
數(shù)據(jù)表
文本字符串
日期
數(shù)據(jù)篩選
數(shù)據(jù)處理
延時處理
數(shù)學(xué)計算器
定時觸發(fā)器
子流程調(diào)用
手動觸發(fā)器
物流地址解析
腳本執(zhí)行器
自定義變量
文件讀取
Webhook
SMTP發(fā)送郵件
文件傳輸
JSON工具
網(wǎng)絡(luò)工具
消息處理
PDF水印工具
文件存儲
API服務(wù)
Http請求
循環(huán)控制
EDI 自定義標(biāo)準(zhǔn)數(shù)據(jù)轉(zhuǎn)換
對象類型判斷
瀏覽器操作
三方應(yīng)用
簡道云
金山數(shù)據(jù)表
抖音
釘釘(自建應(yīng)用)
語雀
金山表單
微信公眾號
企業(yè)微信群機(jī)器人
聚水潭
企業(yè)微信三方授權(quán)
MySQL
SqlServer
ChatGpt
快手
金山輕維表
抖店
維格表
巨量千川
飛書多維表
釘釘機(jī)器人
飛書(自建)
釘釘
百度網(wǎng)盤
QQ郵箱
金山工作表
易知微DTable
MQTT
Doirs
中通快遞
韻達(dá)速遞
企業(yè)微信(代開發(fā))
知乎效果營銷平臺
飛書云文檔
騰訊企業(yè)郵箱
API管理
API管理概述
數(shù)據(jù)概覽
API服務(wù)
訪問憑證
API門戶
API安全密鑰簽名
API監(jiān)控預(yù)警
擴(kuò)展工具
代理網(wǎng)關(guān)
消息處理
管理中心
企業(yè)管理
操作日志
成員管理
開放平臺
開放平臺簡介
接入教程
常見問題
數(shù)環(huán)通ip白名單
最佳實踐
彥祖文化 |通過數(shù)環(huán)通實現(xiàn)全渠道數(shù)據(jù)融合打通
新石器|通過數(shù)環(huán)通實現(xiàn)跨系統(tǒng)、跨部門高效協(xié)同
幫助首頁
開發(fā)工具
腳本配置說明
腳本配置說明
## 一、新增腳本 點擊新增腳本,創(chuàng)建腳本。 ## 二、腳本配置 腳本名稱:可自定義腳本名稱 腳本使用場景碼:請輸入英文 腳本類型:支持 java、JS、python 腳本源代碼:可輸入或直接粘貼代碼 ## 三、腳本示例 ### 1、簽名腳本 如何使用簽名腳本: (1)首先在腳本管理中創(chuàng)建腳本   腳本名稱可以可以自己定義,腳本使用場景編碼使用英文命名,如:sign;腳本類型可以選擇自己使用的開發(fā)語言。 (2)編寫腳本 在應(yīng)用 shuhuan-ipaas-app-libs 的 signer 目錄下開發(fā)簽名類,簽名算法改成通過 java 執(zhí)行=腳本=的方案實現(xiàn)簽名算法,簽名類需要繼承 JavaScriptRunner 類重寫 execute 方法 ``` /** * @author yunmu * @date 2022-03-04 6:44 下午 */ public abstract class JavaScriptRunner { public abstract <T> T execute(Object params); } ``` params 是一個 Map 對象,Map 中會包含以下數(shù)據(jù): * 上下文參數(shù)數(shù)據(jù) * signRequest 待簽名的 http 請求獲取方式: ``` HttpApiRequest apiRequest = (HttpApiRequest) paramsMap.get(SignConfigConstant.SIGN_REQUEST); ``` * 簽名配置中的 signInField 中的信息 * signOutField 簽名的輸出字段 簽名=腳本=示例: ``` package com.shuhuan.ipaas.applibs.signer; import com.aliyun.unicorn.http.MultipartFormData; import com.aliyun.unicorn.http.MultipartFormValue; import com.aliyun.unicorn.http.QueryString; import com.aliyun.unicorn.sdk.HttpApiRequest; import com.aliyun.unicorn.type.Consumer; import com.aliyun.unicorn.type.Parameter; import com.shuhuan.ipaas.common.ResultCode; import com.shuhuan.ipaas.core.encryption.Md5Util; import com.shuhuan.ipaas.exception.IpaasException; import com.shuhuan.ipaas.meta.constants.SignConfigConstant; import com.shuhuan.ipaas.script.java.JavaScriptRunner; import org.apache.commons.lang3.StringUtils; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.TreeMap; /** * @author yunmu * @date 2022-03-05 4:22 下午 */ public class BanniuScriptSigner extends JavaScriptRunner { private static final String METHOD = "method"; private static final String ACCESS_TOKEN = "access_token"; public static final String TIMESTAMP = "timestamp"; private static final String SIGN = "sign"; private static final String APP_KEY = "app_key"; private static final String APP_SECRET=app_secret @Override public <T> T execute(Object params) { if (!(params instanceof Map)){ throw new IpaasException(ResultCode.PARAM_ERROR, "params is not map"); } Map<String,Object> paramsMap = (Map<String, Object>) params; //固定寫法 ,獲取 rquest HttpApiRequest apiRequest = (HttpApiRequest) paramsMap.get(SignConfigConstant.SIGN_REQUEST); // 獲取參數(shù) String appKey = (String) paramsMap.get(APP_KEY); String appSecret = (String) paramsMap.get(APP_SECRET); //獲取 http 請求的數(shù)據(jù) QueryString queryString = apiRequest.getQueryString(); // ******開始業(yè)務(wù)邏輯,根據(jù)實際的簽名要求編寫 TreeMap<String, String> pmap = new TreeMap<>(); queryString.foreachValues((paramKey, value) -> { pmap.put(paramKey, value); }); MultipartFormData formData = apiRequest.getForm(); if (formData != null && !formData.isMultipart()) { apiRequest.getForm().foreach(new Consumer<Parameter<MultipartFormValue>>() { @Override public void accept(Parameter<MultipartFormValue> a) { String v = a.getFirstValue() != null ? a.getFirstValue().getValue() : null; if (METHOD.equals(a.getName())) { pmap.put(METHOD, v); } if (ACCESS_TOKEN.equals(a.getName())) { pmap.put(ACCESS_TOKEN, v); } if (TIMESTAMP.equals(a.getName())) { pmap.put(METHOD, v); } if (ACCESS_TOKEN.equals(a.getName())) { pmap.put(ACCESS_TOKEN, v); } } }); } String stringToSign = sign(pmap, appSecret); String signature = Md5Util.md5(stringToSign, "utf-8").toUpperCase(); //把簽名放入 http 參數(shù) queryString.add(SIGN, signature); // ****結(jié)束業(yè)務(wù)邏輯 //以下為固定格式,不要動 Map<String, String> resultMap = new HashMap<>(); resultMap.put(SignConfigConstant.SIGNATURE, signature); resultMap.put(SignConfigConstant.STRING_TO_SIGN, stringToSign); return (T) resultMap; } // 代碼一, 簽名排序代碼. // pmap 為所有參數(shù), TreeMap 表示為樹形結(jié)構(gòu)的哈希容器 // appSecret 班牛分配給您的密鑰 private String sign(TreeMap<String, String> pmap, String appSecret) { StringBuilder sb = new StringBuilder(appSecret); Iterator i$ = pmap.entrySet().iterator(); while (i$.hasNext()) { Map.Entry<String, String> entry = (Map.Entry) i$.next(); String name = entry.getKey(); String value = entry.getValue(); if (StringUtils.isNoneEmpty(new String[]{name, value})) { sb.append(name).append(value); } } sb.append(appSecret); return sb.toString(); } } ``` (3)在執(zhí)行動作中使用簽名 點擊簽名配置,選擇新增   選擇已經(jīng)創(chuàng)建好的腳本,且可以向腳本中傳遞參數(shù),參數(shù)的 key 可以自己命名,參數(shù)的值可以自己寫成固定的,也可以使用授權(quán)時寫入的變量; 如授權(quán)時的參數(shù):  則可以通過如下形式獲取變量:  在腳本簽名代碼中通過如下方式獲取到數(shù)據(jù): private static final String APP_KEY = "app_key"; private static final String APP_SECRET="app_secret";  ### 2、觸發(fā)器腳本 有些應(yīng)用會推送消息,需要接收消息并處理接收到的數(shù)據(jù),譬如解密數(shù)據(jù)、判斷數(shù)據(jù)是否符合要求,這時需要通過腳本來處理。 (1)定義觸發(fā)器  觸發(fā)器需要輸入動作的名稱和動作 key,動作 key 非常重要,不能重復(fù),必須和代碼中的 eventType 值一樣。 (2)編碼觸發(fā)消息處理腳本 編寫事件回調(diào)數(shù)據(jù)處理 =腳本= 。 例如 java 腳本,必須繼承 JavaScriptRunner, ``` package com.shuhuan.ipaas.applibs.dealPushEventContent.caoliao; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.google.common.collect.Lists; import com.shuhuan.ipaas.script.java.JavaScriptRunner; import lombok.extern.slf4j.Slf4j; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 推送事件 數(shù)據(jù)處理 * 文檔地址: https://cli.im/help/65847 */ @Slf4j public class caoliaoDemo extends JavaScriptRunner { //以下定義的變量是固定的,不要改 private static final String EVENT_TYPE = "eventType"; private static final String BODY = "body"; private static final String EVENT_CONTENTS = "eventContents"; private static final String EVENT_CONTENT = "eventContent"; private static final String ASSET = "asset"; private static final String RESULT = "result"; //結(jié)束固定變量定義 @Override public <T> T execute(Object params) { return (T) buildPushEventOutput(params); } /* { "asset": {}, "body": { "time": "2022-06-30 17:06:39", "event": "FORM_DATA_SUBMIT", "data": { "ref_data": { "created_at": "2022-06-30 17:06:39", "serial_number": "L1000001", "form": { "number": "D20", "name": "會議簽到" }, "fields": { "姓名": "草料", "手機(jī)": "18888648888", "微信名": "CHEN", "身份證號": "330200000000000000", "工號": "FBI100", "單選項": "是" } } } } @return { "result": { "code": 200, "message": "success" }, "eventContents": [{ "eventType": "FORM_DATA_SUBMIT", "eventContent": { "ref_data": { "created_at": "2022-06-30 17:06:39", "serial_number": "L1000001", "form": { "number": "D20", "name": "會議簽到" }, "fields": { "姓名": "草料", "手機(jī)": "18888648888", "微信名": "CHEN", "身份證號": "330200000000000000", "工號": "FBI100", "單選項": "是" } } } }] } */ public static JSONObject buildPushEventOutput(Object params) { JSONObject output = new JSONObject(); if (!(params instanceof Map)) { log.error("當(dāng)前腳本入?yún)㈩愋湾e誤!期望是 Map,但是實際為{},具體值為{}", params.getClass().getName(), JSON.toJSONString(params)); return output; } JSONObject input = (JSONObject) params; /** * 這里的事件內(nèi)容的數(shù)據(jù)類型,有可能是數(shù)組,也可能是對象,具體按照推送方格式為準(zhǔn),作匹配的處理: * 1.解密(不是所有的消息都需要做) * 2.獲取事件的標(biāo)識 * 3.將事件標(biāo)識轉(zhuǎn)換為觸發(fā)器的 key * 4.構(gòu)造接口返回,務(wù)必與推送方要求保持一致 */ /* 1. 解密 該參數(shù)包含秘鑰等信息,如果推送數(shù)據(jù)是密文,可以用該參數(shù)里的秘鑰進(jìn)行解密,例如: 首先獲取授權(quán)時填寫的信息 JSONObject asset = input.getJSONObject(ASSET); String encrypt = input.getJSONObject(BODY).getString("encrypt"); 獲取授權(quán)時填寫的解密秘鑰 String encoding_aes_key = asset.getString("encoding_aes_key"); //按照文檔給的算法進(jìn)行解密 String CIPHER_ALGORITHM = "AES/CBC/PKCS5Padding"; String KEY_ALGORITHM = "AES"; String CHARSET = "UTF-8"; Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); byte[] key = Base64.decodeBase64(encoding_aes_key); SecretKeySpec keySpec = new SecretKeySpec(key, KEY_ALGORITHM); cipher.init(Cipher.DECRYPT_MODE, keySpec, new IvParameterSpec(new byte[16])); String body = new String(cipher.doFinal(Base64.decodeBase64(encrypt)), CHARSET); */ List<JSONObject> eventContents = Lists.newArrayList(); JSONObject data = (JSONObject) input.get(BODY); JSONObject item = new JSONObject(); //2. 獲取對應(yīng)事件的 key。 String event = (String) data.get("event"); //3. 做觸發(fā)器的 key 與事件的 key 映射 if ("FORM_DATA_SUBMIT".equals(event)) { item.put(EVENT_TYPE, "FORM_DATA_SUBMIT"); } else if ("FORM_DATA_EDITED".equals(event)) { item.put(EVENT_TYPE, "FORM_DATA_EDITED"); } else if ("FORM_DATA_REVIEW".equals(event)) { item.put(EVENT_TYPE, "FORM_DATA_REVIEW"); } //4. 對應(yīng)事件的輸出內(nèi)容,這里的內(nèi)容是外部應(yīng)用推送過來的原始數(shù)據(jù),與觸發(fā)器的輸出字段保持一致 item.put(EVENT_CONTENT, JSON.parseObject(data.getString("data"))); eventContents.add(item); output.put(EVENT_CONTENTS, eventContents); //推送事件后的響應(yīng)結(jié)果,必須和推送方要求的返回結(jié)果一致,固定寫法 Map<String, Object> result = new HashMap<>(16); result.put("code", 0); result.put("message", "success"); output.put(RESULT, result); return output; } } 腳本返回數(shù)據(jù)格式必須是 { "result": { "code": 200, "message": "success" }, "eventContents": [{ "eventType": "FORM_DATA_SUBMIT", "eventContent": { //外部推送的數(shù)據(jù) } }] } 如: { "result": { "code": 200, "message": "success" }, "eventContents": [{ "eventType": "FORM_DATA_SUBMIT", "eventContent": { //外部推送的數(shù)據(jù) "ref_data": { "created_at": "2022-06-30 17:06:39", "serial_number": "L1000001", "form": { "number": "D20", "name": "會議簽到" }, "fields": { "姓名": "草料", "手機(jī)": "18888648888", "微信名": "CHEN", "身份證號": "330200000000000000", "工號": "FBI100", "單選項": "是" } } } }] } ``` ## 四、腳本 SDK 下載 Java 腳本 SDK:[shuhuan-ipaas-script-demo.zip](https://sh-assets.oss-cn-hangzhou.aliyuncs.com/sdk/shuhuan-ipaas-script-demo.zip) *注:可在下載 SDK Demo 中進(jìn)行編寫腳本,SDK Demo 中所引用的依賴均可以在數(shù)環(huán)通腳本中使用。*
上一篇
控件類型配置
下一篇
內(nèi)置函數(shù)
手機(jī)掃碼
復(fù)制鏈接
手機(jī)掃一掃轉(zhuǎn)發(fā)分享
復(fù)制鏈接
Markdown文件
分享
鏈接
類型
密碼
更新密碼
主站蜘蛛池模板:
山东致合必拓环保科技股份有限公司
|
郑州阳光房|封阳台|钢结构【河南郑州如意阳光房门窗有限公司】
|
陕西锐锋建筑安装有限公司,锐锋建筑,总承包,专业分包,市政综合,劳务,水电钢构,铁路公路,房建,房屋建筑施工
|
外墙涂料_真石漆_真石漆批发_河南宝润达真石漆厂家
|
厦门空压机-厦门空压机出租-厦门钻机出租-厦门岩立盛机电设备有限公司
|
天津网站制作|网站建设|营销型网站建设|筑美网络---天津做网站公司
|
新密耐火材料厂家价格-河南郑州荣盛窑炉耐火材料有限公司
|
一站式管材,型材,板材,焊接加工等工程材料批发商-佛山市佛孟钢铁有限公司
|
气胀轴丨安全夹头丨电磁制动器丨纠偏系统丨磁粉离合器丨张力控制器厂家- 东莞天机通信科技有限公司
|
拓普思(常州)智能科技有限公司-青少年无人机教育培训比赛课程加盟拓活力
|
廊坊大地木业有限公司
|
阻垢剂|缓蚀剂|杀菌剂|分散剂|水处理剂|印染助剂|水处理药剂|造纸助剂|膜阻垢剂|缓蚀剂|HEDP|ATMP|螯合剂-山东凯瑞化学有限公司 水处理药剂生产厂家
|
中昕国际项目管理有限公司-官方网站
|
转盘萃取塔,DMF回收塔生产厂家-无锡弘鼎华化工设备有限公司
|
无锡大型数控龙门铣加工中心,精密焊接件制造,机械设备加工-无锡嘉迅机械科技有限公司
|
气胀轴丨安全夹头丨电磁制动器丨纠偏系统丨磁粉离合器丨张力控制器厂家- 东莞天机通信科技有限公司
|
水环式真空泵-旋片式真空泵-上海飞鲁泵业科技有限公司
|
移动石料破碎机-颚式锤式反击式破碎机设备厂家_山东.青州富康机械
|
塑胶篮球场施工|塑胶网球场施工|幼儿园塑胶施工|石家庄亚强体育公司
|
污泥处理设备|污泥固化固液分离压泥机压滤机厂家-山东冠诚开山贸易
|
空气能热水器|空气能热水器工程|太阳能热水器工程|蓝冠机电
|
气动量仪厂家-郑州华峰仪器有限公司
|
液体灌装机_全自动灌装机_大桶灌装机_200L灌装机_涂料油漆灌装机-昆山灌装自动化设备有限公司
|
昆明护栏网厂家_隔离栅_围栏网_石笼网「13年生产经验」-云南北辛商贸
|
深圳彩盒印刷-纸盒包装-不干胶标签印刷-深圳印刷厂家-深圳贝的印刷
|
卧式球磨机_干法球磨机_尼龙球磨机-无锡市少宏粉体科技有限公司 卧螺离心机-固液分离机-台州春鼎机械制造有限公司
|
实验室超纯水机-超纯水机-超纯水仪-上海赫恩实业有限公司
|
铝型材定制_东莞铝型材_散热器铝型材_工业铝合金型材挤压加工生产厂家价格-中亚铝业
|
幼儿园设计公司/南昌酒店装修/办公室/餐厅/民宿/店面/展厅/装修设计公司-益昌装饰集团
|
网带式等温正火生产线_燃气式铝合金加热炉_燃气式烘干窑炉-湖州中科炉业科技有限公司
|
浙江云野科技有限公司_智慧旅游规划_智慧景区管理系统_全域旅游解决方案-云野科技旅游大数据管理平台
|
中捷摇臂钻,数控钻床,沈阳中捷设备机床厂官网_沈阳中捷数控摇臂钻床厂
|
江苏广分检测技术有限公司、电力安全工具检测、苏州绝缘工具检测、昆山电力安全工具检测-广分检测技术(苏州)有限公司
|
无锡泡沫包装生产厂家-江阴源欧包装材料有限公司
|
盆底肌修复仪器-产后康复脉冲磁训练仪-南京佳澜健康管理有限公司
|
太阳能杀虫灯-农业用杀虫灯-果园灭虫灯厂家「尚科杀虫灯|
|
上海希喆机械有限公司-Schunk雄克,雄克卡盘, 雄克机械手, B+R贝加莱, ELCIS编码器,艾西斯编码器, TWK编码器,Nexen,Joyce dayton升降机,Thomson汤姆森,TPG减速机,INA导轨。
|
制砂生产线,河卵石制砂机,洗砂机-巩义市铭德矿山设备厂
|
橡皮艇_冲锋舟_充气钓鱼船_橡皮艇价格_海威龙橡皮艇生产厂家-首页
|
气体检测仪,多功能气体检测仪,四合一检测仪,氯气检测仪,有机挥发气体检测仪,气体报警器-南京诺邦电子科技有限公司
|
图表秀——免费在线图表制作工具,数据可视化工具
|