java中的工作流要怎样实现_java工作流开发要怎么实现?

java中的工作流要怎样实现_java工作流开发要怎么实现?Java工作流的应用在目前十分广泛,能够熟练的实现工作流也是一种本事,本篇文章就让小编带你了解下其中的实现关键。我们知道,工作流的实现主要依靠反射机制,想要实现它,首先我们先来创建一张工作流表创建一张工作流表如:主键|工作流Code|工作流内容其中工作流内容为Json格式工作流内容{“procCode”:”OPS”,”procName”:”c端补齐(乘客信息补全)”,”taskCo…

大家好,又见面了,我是你们的朋友全栈君。

Java工作流的应用在目前十分广泛,能够熟练的实现工作流也是一种本事,本篇文章就让小编带你了解下其中的实现关键。

我们知道,工作流的实现主要依靠反射机制,想要实现它,首先我们先来创建一张工作流表

创建一张工作流表

如:主键 | 工作流Code | 工作流内容

其中工作流内容为Json格式

工作流内容{

“procCode”: “OPS”

, “procName”: “c端补齐(乘客信息补全)”

, “taskControlVoList”: [

{

“sortNo”: “10”

, “taskCode”: “OPC”

, “taskName”: “检查对应的订单信息是否存在”

, “tasklassName”: “com.xf.flow.service.impl.OrderPeople10ServImpl”

}

, {

“sortNo”: “20”

, “taskCode”: “OPD”

, “taskName”: “乘客数据库落库”

, “tasklassName”: “com.xf.flow.service.impl.OrderPeople20ServImpl”

}

, {

“sortNo”: “90”

, “taskCode”: “RSP”

, “taskName”: “响应消息”

, “tasklassName”: “com.xf.flow.service.impl.ApiResponseServImpl”

}

]

}

aava代码现根据工作流的Code 获取当前的工作流

jsonStr ————>JsonObject————>获取taskControlVoList

java的工作流代码@Override

public ApiResponse deal(String itemNo, Object objVo, String skey, InnerVo innerVo)

{

ApiResponse apiResponse = new ApiResponse();

//查询itemNo获取流程实例

ProcControlVo procControlVo = codeLibraryDao.queryProcConfig(itemNo);

if (procControlVo == null)

{

return new ApiResponse(ResponseCodeEnums.stream_no_exist);

}

List  taskControlVoList = procControlVo.getTaskControlVoList();

taskControlVoList.sort((TaskControlVo h1, TaskControlVo h2) – > h1.getSortNo()

.compareTo(h2.getSortNo()));

Iterator  itTask = taskControlVoList.iterator();

//初始化内部数据表

String dataNo = taskManagerServ.initData(itemNo, skey, innerVo);

//循环依次执行流程任务

String taskNo = null;

while (itTask.hasNext())

{

TaskControlVo taskControlVo = itTask.next();

String taskClassName = taskControlVo.getTasklassName();

String taskItemNo = taskControlVo.getTaskCode();

String taskName = taskControlVo.getTaskName();

try

{

//初始化任务

taskNo = taskManagerServ.initTask(taskItemNo, dataNo, innerVo);

//执行任务

TaskServ taskServ = (TaskServ) SpringFactory.getBean(Class.forName(taskClassName));

taskServ.init(taskNo, objVo);

TaskAnswerVo taskAnwserVo = taskServ.deal(taskNo, objVo);

//判断任务执行结果

apiResponse = taskAnwserVo.getApiResponse();

if (StringUtils.equals(ResponseCodeEnums.success.getStatus(), apiResponse.getStatus()))

{

//完成任务

logger.info(“==========>>>>> task execute success !!! taskCode={}, taskName={}, status={}, msg={}, nextTask={}”

, taskItemNo, taskName, apiResponse.getStatus(), apiResponse.getMessage(), taskAnwserVo.isNextTask());

taskManagerServ.finTask(taskNo, apiResponse.getMessage());

}

else

{

//异常任务

logger.info(“==========>>>>> task execute error !!! taskCode={}, taskName={}, status={}, msg={}, nextTask={}”

, taskItemNo, taskName, apiResponse.getStatus(), apiResponse.getMessage(), taskAnwserVo.isNextTask());

taskManagerServ.errTask(taskNo, apiResponse.getMessage());

}

//判断流程是否继续

if (!taskAnwserVo.isNextTask())

{

break;

}

}

catch (Exception e)

{

//异常任务

String errorMsg = getStackTrace(e);

taskManagerServ.errTask(taskNo, errorMsg);

logger.error(“==========>>>>> Execute Task Error!!! skey={}, taskControlVo={}, errorMsg={}”, skey, taskControlVo, errorMsg);

//响应异常

return new ApiResponse(ResponseCodeEnums.flow_error);

}

}

if (StringUtils.equals(ResponseCodeEnums.success.getStatus(), apiResponse.getStatus()))

{

//归档完成流程

taskManagerServ.finData(dataNo);

}

return apiResponse;

}

d8ea3beebaec94831a5b4138d9226da3.png

SpringFactory实现类/**

* Created by

*/

@Component

public class SpringFactory implements ApplicationContextAware

{

private static ApplicationContext applicationContext;

@Override

public void setApplicationContext(ApplicationContext applicationContext) throws BeansException

{

if (SpringFactory.applicationContext == null)

{

SpringFactory.applicationContext = applicationContext;

}

}

//获取applicationContext

public static ApplicationContext getApplicationContext()

{

return applicationContext;

}

//通过name获取 Bean.

public static Object getBean(String name)

{

return getApplicationContext()

.getBean(name);

}

//通过class获取Bean.

public static  T getBean(Class  clazz)

{

return getApplicationContext()

.getBean(clazz);

}

//通过name,以及Clazz返回指定的Bean

public static  T getBean(String name, Class  clazz)

{

return getApplicationContext()

.getBean(name, clazz);

}

}

以上就是本篇文章的所有内容,需要了解其他java常见问题及解决方法的小伙伴们请持续关注本网站吧。

推荐阅读:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/156526.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • arcgis python 教程-ArcGIS Python 入门到精通,视频教程下载

    arcgis python 教程-ArcGIS Python 入门到精通,视频教程下载课程介绍:本课程15章42个视频,基于ArcGIS10.2版本,涵盖了如何使用Python开发ArcGIS自定义工具,具体包括:编辑器的使用安装;列表函数使用;汉字乱码处理;游标(cursor)查询、更新和插入;几何图形生成和坐标导出;属性查询和空间查询;字段映射(FieldMappings)和值表(ValueTable)使用;拓扑检查和创建的拓扑处理;文件TXT、XLS和ArcGIS数据转换;使…

    2022年6月26日
    30
  • DHCP_RELAY(Option60与Option82)[通俗易懂]

    DHCP_RELAY(Option60与Option82)[通俗易懂]DHCP_RELAY(Option60与Option82):http://wenku.baidu.com/view/2bac6d758e9951e79b8927e7.htmlDHCPOption82:DHCPRelayAgentInformationOption.提供DHCP的认证和安全机制。CID:AgentCircuitID RID:Agen

    2022年10月15日
    0
  • 搭建Eurake集群

    搭建Eurake集群eureka作为SpringCloud的服务发现与注册中心,在整个的微服务体系中,处于核心位置。单一的eureka服务,显然不能满足高可用的实际生产环境,这就要求我们配置一个能够应对各种突发情况,具有较强容灾能力的eureka集群服务。其实我们只需要在部署时候,对eureka的配置文件做相应的修改,运行即可。在项目中,创建三个名字分别为eureka01,eureka02,eureka03的eur…

    2022年6月4日
    38
  • 高通骁龙430系列-MSM8937 ( Cortex-A53架构)「建议收藏」

    高通骁龙430系列-MSM8937 ( Cortex-A53架构)「建议收藏」核心板特性产品尺寸小,便于客户集成,减少产品体积;支持4GLTE超高速上网,单板兼容移动/联通/电信2G/3G/4G;丰富的接口配置,满足大多数客户需求;高通骁龙8937(高通骁龙430系列)产品首款核心板产品;产品单面布板,可有效降低产品厚度;产品质量稳定可靠;提高开发效率。客户系统架构无需从零开始;降低开发难度。客户重点放在应用方案开发上,不必关注无线网络方案;增强可维护性。通过核心板的更迭…

    2022年4月19日
    736
  • IDEA下Log4j使用教程

    IDEA下Log4j使用教程 2015年12月14日15:30:21阅读数:13467Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIXSyslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些…

    2022年9月5日
    3
  • 服务器基础知识_服务器初学者入门

    服务器基础知识_服务器初学者入门定义:从广义上讲,服务器是指网络中能对其它机器提供某些服务的计算机系统(如果一个PC对外提供ftp服务,也可以叫服务器)。从狭义上讲,服务器是专指某些高性能计算机,能通过网络,对外提供服务。相对于普通

    2022年8月1日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号