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场景安装运行

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

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

    • 🍄说明
    • 🌿Springboot下的配置项
    • 🌱Spring下的配置项
    • 🌵其他场景代码设置配置项
  • 🗂规则以及配置源

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

      • 配置说明
      • 轮询模式配置
      • 订阅模式配置
    • 📙自定义配置源
  • 🔗常规组件

    • 📎普通组件
    • ✂️选择组件
    • ⛓布尔组件
    • 🧬次数循环组件
    • ⌛️迭代循环组件
  • 🧩EL规则的写法

    • 🍄说明
    • 🌴串行编排
    • 🎋并行编排
    • 🌾选择编排
    • 🌵条件编排
    • 🌳循环编排
    • 🎃捕获异常表达式
    • 🍄与或非表达式
    • 🍁使用子流程
    • 🍂使用子变量
    • 💐复杂编排例子
    • 🌻关于分号
    • 🌰关于注释
    • 🐚组件名包装
    • 🔆验证规则
  • 🌮数据上下文

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

    • 🍄说明
    • 🎡执行方法
    • 🎢流程入参
    • 🎈LiteflowResponse对象
      • 流程执行是否成功
      • 获取异常信息
      • 获得执行步骤详细信息
      • 上下文数据
      • 获得步骤字符串信息
      • 获得超时对象
  • 🍋脚本组件

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

      • 🥏Groovy脚本引擎
      • 🧀Javascript脚本引擎
      • ☕️Java脚本引擎
      • 🥞QLExpress脚本引擎
      • 🍧Python脚本引擎
      • 🍝Lua脚本引擎
      • 🥐Aviator脚本引擎
      • 🥠Kotlin脚本引擎
    • 🍣脚本与Java进行交互
    • 🍱多脚本语言混合共存
    • 🌯文件脚本的定义
    • 🍘动态刷新脚本
    • 🍦验证脚本
    • 🗑卸载脚本
  • 🍇声明式组件

    • 🥭什么叫声明式组件
    • 🧅类级别式声明
    • 🥥方法级别式声明
  • 🎲用代码动态构造规则

    • 🍄说明
    • 🥜构造Node
    • 🌰构造EL
    • 🍞构造Chain
  • 🍼元数据管理

    • ⛰概念以及介绍
    • 🍖平滑热刷新
    • 🍮启动不检查规则
    • 🫔查看指定规则下的所有组件
  • 🧮决策路由

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

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

    • 🍒前置和后置组件
    • 🍌本地规则文件监听
    • 🥠组件降级
    • 🍉组件参数
    • 🍑组件别名
    • 🍍组件标签
    • 🥝组件事件回调
    • 🐋组件回滚
    • 🥑隐式子流程
    • 🍕私有投递
    • 🍣组件重试
    • 🫐EL中的重试
    • 🥦异步循环模式
    • ⏱️超时控制
    • 🥯链路继承
    • 🍪组件切面
    • 🍡步骤信息
    • 🧊异常
    • 🧇打印信息详解
    • 🧁自定义请求Id
    • 🫕快速解析模式
    • 🌭不同格式规则加载
    • 🥗异步线程池自定义
    • 🍿自定义组件执行器
    • 🍥简单监控
    • 🧉XML的DTD
  • ⛱测试用例以及示例

    • 🪁测试用例
    • 🪀DEMO案例
  • 🪂性能表现
  • v2.12.X文档
  • 🛩执行器
铂赛东
2022-07-02
目录

🎈LiteflowResponse对象

在执行器返回中,用的最多的就是返回一个LiteFlowResponse对象。

这个对象里面包含了很多结果数据和过程数据。

提示

这个对象并不适合进行序列化返回,应用层如果想返回一些数据,应当自己构建对象。

# 流程执行是否成功

你可以通过以下方法来判断一个流程是否执行成功:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, CustomContext.class);
boolean isSuccess = response.isSuccess();

# 获取异常信息

如果一个流程isSuccess为false,则必然有异常信息,你可以通过以下方法来获得异常:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, CustomContext.class);
if (!response.isSuccess()){
  Exception e = response.getCause();
}

关于异常的解释请详细查看异常这一章节。

# 获得执行步骤详细信息

结果信息中也封装了流程执行每一步的详细信息,你可以通过这个方法来获取:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, CustomContext.class);
Map<String, CmpStep> stepMap = response.getExecuteSteps();

你也可以通过这样的方式也取到一个队列:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, CustomContext.class);
Queue<CmpStep> stepQueue = response.getExecuteStepQueue();

关于这上面2个方法的区别和步骤信息的详细请参考步骤信息。

# 上下文数据

流程在执行过程中,会对上下文数据进行读写操作。一个流程的返回数据也应当包含在上下文中。

你获得了LiteFlowResponse对象之后,可以这样获得上下文Bean:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, CustomContext.class);
CustomContext context = response.getContextBean(CustomContext.class);
//对于只有一个上下文的response来说,用下面这句也是等价的
//CustomContext context = response.getFirstContextBean();

对于多上下文来说,也是一样的用法:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, OrderContext.class, UserContext.class);
OrderContext orderContext = response.getContextBean(OrderContext.class);
UserContext userContext = response.getContextBean(UserContext.class);

# 获得步骤字符串信息

获得一个简单易懂的组件步骤的字符串拼装信息:

LiteflowResponse response = flowExecutor.execute2Resp("chain1", 初始参数, CustomContext.class);
String stepStr = response.getExecuteStepStrWithTime();

这个字符串打印出来结果如下:

a[组件A]<201>==>b[组件B]<300>==>m[组件M]<1205>

这里的表达形式为组件ID[组件别名]<耗时毫秒>。关于如何设置组件别名可以参考组件别名。

同时,response对象里还提供了getExecuteStepStrWithoutTime这个方法,用于返回不带有耗时时间的步骤字符串。

提示

事实上,在每一个流程执行结束后,框架会自动打印这个步骤字符串,所以无需你自己获取打印。

这里只是说明如何获取,如果你要持久化下来,可以这样获取。

# 获得超时对象v2.12.3+

你可以调用liteflowResponse.getTimeoutItems()方法来获得超时的对象Id。

帮助我们改善此文档 (opens new window)
上次更新: 2025/02/16, 21:26:30
🎢流程入参
🌭脚本语言介绍

← 🎢流程入参 🌭脚本语言介绍→

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