LiteFlow LiteFlow
💒首页
  • v2.15.0(当前版本)
  • What's New

    • 🌈What' s New In LiteFlow v2.15.0?
  • 历史版本

    • v2.13.X
    • v2.12.X
    • v2.11.X
    • v2.10.X
    • v2.9.X
    • v2.8.X
  • 升级指南

    • 🌈2.13.0升级指南
    • 2.12.4升级指南
    • 2.12.0升级指南
    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
👑LF CLUB社区
  • 常见问题
  • 专题解释

    • 如何理解上下文这个概念?
    • Slot是一个什么样的概念,在框架中起到什么样的作用?
💖赞助
🧩IDEA插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
👥加入群聊
🧤谁在使用
  • Gitee (opens new window)
  • GitCode (opens new window)
  • Github (opens new window)

广告采用随机轮播方式显示 ❤️成为赞助商
💒首页
  • v2.15.0(当前版本)
  • What's New

    • 🌈What' s New In LiteFlow v2.15.0?
  • 历史版本

    • v2.13.X
    • v2.12.X
    • v2.11.X
    • v2.10.X
    • v2.9.X
    • v2.8.X
  • 升级指南

    • 🌈2.13.0升级指南
    • 2.12.4升级指南
    • 2.12.0升级指南
    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
👑LF CLUB社区
  • 常见问题
  • 专题解释

    • 如何理解上下文这个概念?
    • Slot是一个什么样的概念,在框架中起到什么样的作用?
💖赞助
🧩IDEA插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
👥加入群聊
🧤谁在使用
  • Gitee (opens new window)
  • GitCode (opens new window)
  • Github (opens new window)
  • 🍤LiteFlow简介
  • 🍓项目特性
  • 🧁环境支持

    • 🗣环境支持说明
    • ☕️JDK支持度
    • 🌿Springboot支持度
    • 🌱Spring的支持度
  • 🍟快速开始(Hello world)

    • 🍄说明
    • 🌿Springboot场景安装运行

      • 🧬依赖
      • ⚙️配置
      • 🛫执行
    • 🌱Spring场景安装运行

      • 🧬依赖
      • ⚙️配置
      • 🛫执行
    • 🍩Solon场景安装运行

      • 🧬依赖
      • ⚙️配置
      • 🛫执行
    • 🌵其他场景安装运行

      • 🍄说明
      • 🧬依赖
      • ⚙️配置
      • 🛫执行
  • 🍢配置项

    • 🍄说明
    • 🌿Springboot下的配置项
    • 🌱Spring下的配置项
    • 🍩Solon下的配置项
    • 🌵其他场景代码设置配置项
  • 🔗组件

    • 🛍继承式组件

      • 📎普通组件
      • ✂️选择组件
      • ⛓布尔组件
      • 🧬次数循环组件
      • ⌛️迭代循环组件
      • 🏄LiteflowComponent
      • 🛀组件内方法覆盖和调用
    • 🎁声明式组件

      • 🥭什么叫声明式组件
      • 🧅类级别式声明
      • 🥥方法级别式声明
  • 🧩EL规则

    • 🍄说明
    • 🌴串行编排
    • 🎋并行编排
    • 🌾选择编排
    • 🌵条件编排
    • 🌳循环编排
    • 🥦异步循环模式
    • 🎃捕获异常表达式
    • 🍄与或非表达式
    • 🍁使用子流程
    • 🍂使用子变量
    • 💐复杂编排例子
    • 🍒前置和后置编排
    • 🍉组件参数语法

      • 说明
      • tag语法
      • data语法
      • bind语法
    • 🫐重试语法
    • ⏱️超时控制语法
    • 🥯链路继承
    • 🔆验证规则
    • 🌰关于注释
    • 🌻关于分号
    • 🐚组件名包装
  • 🌮上下文

    • 🍄说明
    • 🌯数据上下文的定义和使用
    • 🪶用初始化好的上下文传入
    • 🥨给上下文设置别名
    • 🥙上下文参数注入
    • 🪴用表达式获取上下文参数
  • 🛩执行器

    • 🍄说明
    • 🎡执行方法
    • 🎢流程入参
    • 🎈LiteflowResponse对象
  • 🍋脚本组件

    • 🌭脚本语言介绍
    • 🍫脚本语言种类

      • ☕️Java脚本引擎
        • 介绍
        • 使用liteflow-script-javax
        • 使用liteflow-script-javax-pro
        • 如何取Spring上下文中的数据
      • 🥏Groovy脚本引擎
      • 🧀Javascript脚本引擎
      • 🥞QLExpress脚本引擎
      • 🍧Python脚本引擎
      • 🍝Lua脚本引擎
      • 🥐Aviator脚本引擎
      • 🥠Kotlin脚本引擎
    • 🍣脚本与Java进行交互
    • 🍱多脚本语言混合共存
    • 🌯文件脚本的定义
    • 🍘动态刷新脚本
    • 🍦验证脚本
    • 🗑卸载脚本
  • 🗂规则配置源

    • 📕本地规则文件配置
    • 📘SQL数据库配置源
    • 📗ZK规则文件配置源
    • 📋Nacos配置源
    • 🗄Etcd配置源
    • 📜Apollo配置源
    • 📑Redis配置源

      • 配置说明
      • 轮询模式配置
      • 订阅模式配置
    • 📙自定义配置源
  • 🍼元数据管理

    • ⛰元数据操作器
    • 🍖平滑热刷新
    • 🍮启动不检查规则
    • 🥨启动不检查脚本
  • 🌌异步中的线程池

    • 💧说明
    • 🐋FlowExecutor层面的线程池
    • 🐠组件异步层面的线程池
  • 🎲动态构造

    • 🍄说明
    • 🥜构造Node
    • 🌰构造EL
    • 🍞构造Chain
  • 🧮决策路由

    • 🏖概念以及介绍
    • 🍽决策路由用法
  • 😸生命周期

    • 🐮启动时生命周期
    • 🐳执行时生命周期
  • 🎨高级特性

    • 🍌本地规则文件监听
    • 🥠组件降级
    • 🍑组件别名
    • 🥝组件事件回调
    • 🐋组件回滚
    • 🥑隐式子流程
    • 🍕私有投递
    • 🍪组件切面
    • 🍡步骤信息
    • 🧊异常
    • 🧇打印信息详解
    • 🧁自定义请求Id
    • 🫕快速解析模式
    • 🌭不同格式规则加载
    • 🍿自定义组件执行器
    • 🍥简单监控
    • 🧉XML的DTD
  • ⛱测试用例以及示例

    • 🪁测试用例
    • 🪀DEMO案例
  • 🪂性能表现
  • v2.13.X文档
  • 🍋脚本组件
  • 🍫脚本语言种类
铂赛东
2023-08-28
目录

☕️Java脚本引擎

# 介绍

LiteFlow支持了用Java本身作为脚本语言的特性。用Java作为脚本语言也是LiteFlow首推的脚本语言。

也就是说,在写组件脚本时,你可以完全用Java自身的语法来写脚本。同样这部分的脚本,也是可以进行热刷新的。

LiteFlow提供了三种Java脚本的插件,分别为:

  • liteflow-script-java:以Janino为底层来实现。版本支持:v2.11.0+,这个插件从v2.13.0开始起不再推荐使用,今后也不会有任何维护和更新
  • liteflow-script-javax:以Liquor为底层来实现。版本支持:v2.12.4+
  • liteflow-script-javax-pro:升级版本,完全同静态java写法一样。版本支持:v2.13.0+

以下针对于liteflow-script-javax和liteflow-script-javax-pro这2个插件进行说明。

如果你使用2.13.X系列版本,推荐使用liteflow-script-javax-pro。

如果你使用2.12.X系列版本,推荐使用liteflow-script-javax。

# 使用liteflow-script-javax

你需要额外依赖LiteFlow提供的脚本插件:

<dependency>
    <groupId>com.yomahub</groupId>
    <artifactId>liteflow-script-javax</artifactId>
    <version>2.13.2</version>
</dependency>

提示

使用以Liquor为核心的javax插件,部署运行的时候必须为JDK,而不能是JRE,这点要注意下。

使用liteflow-script-javax插件,需要像如下去定义,以下是个例子:

<node id="s1" name="普通脚本1" type="script" language="java">
    <![CDATA[
    import cn.hutool.core.collection.ListUtil;
    import com.alibaba.fastjson2.JSON;
    import com.yomahub.liteflow.script.body.CommonScriptBody;
    import com.yomahub.liteflow.slot.DefaultContext;
    import com.yomahub.liteflow.spi.holder.ContextAwareHolder;
    import com.yomahub.liteflow.test.script.javax.common.cmp.Person;
    import com.yomahub.liteflow.test.script.javax.common.cmp.TestDomain;
    import com.yomahub.liteflow.script.ScriptExecuteWrap;
    import java.util.List;
    import java.util.function.ToIntFunction;

    public class Demo implements CommonScriptBody {
        public Void body(ScriptExecuteWrap wrap) {
            int v1 = 2;
            int v2 = 3;
            DefaultContext ctx = wrap.getCmp().getFirstContextBean();
            ctx.setData("s1", v1 * v2);

            TestDomain domain = ContextAwareHolder.loadContextAware().getBean(TestDomain.class);
            System.out.println(domain);
            String str = domain.sayHello("jack");
            ctx.setData("hi", str);

            List<Person> personList = ListUtil.toList(
                    new Person("jack", 15000),
                    new Person("tom", 13500),
                    new Person("peter", 18600)
            );

            int totalSalary = personList.stream().mapToInt(Person::getSalary).sum();

            System.out.println(totalSalary);
            ctx.setData("salary", 47100);

            return null;
        }
    }
    ]]>
</node>

如果你要实现其他种类的组件,请替换实现的接口:

script:普通脚本节点,需要实现CommonScriptBody接口,脚本里返回null即可。

switch_script:选择脚本节点,需要实现SwitchScriptBody接口,脚本里需要返回选择的节点Id。

boolean_script:布尔脚本节点,需要实现BooleanScriptBody接口,脚本里需要返回true/false。

for_script:数量循环节点,需要实现ForScriptBody接口,脚本里需要返回数值类型,表示循环次数。

之前类方法通过this调用的,现在都用wrap.getCmp()来替换。

但是在这个插件中,你无法覆盖其他方法,比如说isAccess或者onSuccess等方法。

# 使用liteflow-script-javax-pro

你需要额外依赖LiteFlow提供的脚本插件:

<dependency>
    <groupId>com.yomahub</groupId>
    <artifactId>liteflow-script-javax-pro</artifactId>
    <version>2.13.2</version>
</dependency>

提示

使用以Liquor为核心的javax插件,部署运行的时候必须为JDK,而不能是JRE,这点要注意下。

这个为上一个插件的升级版本,在这个插件中,定义java完全是按照静态java类的方式去定义了,以下是一个例子:

<node id="s1" name="普通脚本1" type="script" language="java">
    <![CDATA[
    import cn.hutool.core.collection.ListUtil;
    import com.yomahub.liteflow.core.NodeComponent;
    import com.yomahub.liteflow.slot.DefaultContext;
    import com.yomahub.liteflow.spi.holder.ContextAwareHolder;
    import com.yomahub.liteflow.test.script.javaxpro.common.cmp.Person;
    import com.yomahub.liteflow.test.script.javaxpro.common.cmp.TestDomain;

    import java.util.List;

    public class Demo extends NodeComponent {
        @Override
        public void process() throws Exception {
            int v1 = 2;
            int v2 = 3;
            DefaultContext ctx = this.getFirstContextBean();
            ctx.setData("s1", v1 * v2);

            TestDomain domain = ContextAwareHolder.loadContextAware().getBean(TestDomain.class);
            System.out.println(domain);
            String str = domain.sayHello("jack");
            ctx.setData("hi", str);

            List<Person> personList = ListUtil.toList(
                    new Person("jack", 15000),
                    new Person("tom", 13500),
                    new Person("peter", 18600)
            );

            int totalSalary = personList.stream().mapToInt(Person::getSalary).sum();

            System.out.println(totalSalary);
            ctx.setData("salary", 47100);
        }
    }
    ]]>
</node>

可以看到,在升级版的插件中,其定义java的方式完全和类里定义的完全一致了。这意味着,你可以用this来进行调用,你也可以覆盖其他方法如isAccess,beforeProcess等。

提示

即便是java脚本组件,目前还依旧不可以定义迭代循环组件。这意味着即使你用了java-pro插件,你现在可以继承NodeIteratorComponent,但是你依旧无法正确执行。

请用for_script组件来代替。

# 如何取Spring上下文中的数据

值得注意的是,以上2个脚本插件虽然完全是Java的语法,但是你无法用@Resource或者@Autowired来进行注入spring的bean。

LiteFlow提供一个方法,用来获取Spring中的bean数据,如下示例:

UserDomain domain = ContextAwareHolder.loadContextAware().getBean(UserDomain.class);

这样就可以获得在spring上下文中注入的UserDomain对象了。

帮助我们改善此文档 (opens new window)
上次更新: 2025/08/28, 11:38:35
🌭脚本语言介绍
🥏Groovy脚本引擎

← 🌭脚本语言介绍 🥏Groovy脚本引擎→

Theme by Vdoing | Copyright © 2020-2025 铂赛东 | MIT License
沪ICP备18012955号-2
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式