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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • STL之Stringstream字符串流使用总结

    STL之Stringstream字符串流使用总结如果你已习惯了风格的转换,也许你首先会问:为什么要花额外的精力来学习基于的类型转换呢?也许对下面一个简单的例子的回顾能够说服你。假设你想用sprintf()函数将一个变量从int类型转换到字符串类型。为了正确地完成这个任务,你必须确保证目标缓冲区有足够大空间以容纳转换完的字符串。此外,还必须使用正确的格式化符。如果使用了不正确的格式化符,会导致非预知的后果。下面是一个例子:intn

    2022年6月6日
    22
  • JavaScript中的类型判断

    JavaScript中的类型判断js 中的类型判断 1 使用 typeof 进行类型判断 2 使用 instanceof 判断对象 3 使用 Array isArray 判断数组 1 使用 typeof 进行类型判断 functionfun console log 数字的类型为 typeof 1 console log 字符串的类型为 typeof hello console log 布尔值的类型为 typeof true console log undefined 的类型为

    2025年6月29日
    2
  • 猿创征文|点亮JAVA技术之灯(线程篇)「建议收藏」

    猿创征文|点亮JAVA技术之灯(线程篇)「建议收藏」线程安全就是说多线程访问同一段代码,不会产生不确定的结果。又是一个理论的问题,各式各样的答案有很多,我给出一个个人认为解释地最好的:如果你的代码在多线程下执行和在单线程下执行永远都能获得一样的结果,那么你的代码就是线程安全的。(1)不可变像String、Integer、Long这些,都是final类型的类,任何一个线程都改变不了它们的值,要改变除非新创建一个,因此这些不可变对象不需要任何同步手段就可以直接在多线程环境下使用(2)绝对线程安全不管运行时环境如何,调用者都不需要额外的同步措施。……….

    2022年10月22日
    0
  • Win10自动更新永久关闭,有效的Win10强制更新关闭方法,禁止windows10自动更新,禁止update medic service ,win10显示更新并关机没有单独的关机按钮[通俗易懂]

    Win10自动更新永久关闭,有效的Win10强制更新关闭方法,禁止windows10自动更新,禁止update medic service ,win10显示更新并关机没有单独的关机按钮[通俗易懂]禁用update服务,光这个不行,下边还有windowsupdatemedicservice禁止流程鼠标右键此电脑–>管理–>服务和应用程序–>服务–>windowsupdate–>选择禁用,如果该服务已经启动,记得点击停止,然后点击右下角的应用再确定,确定,就禁止了update服务,但是这个貌似有时候就又启动了,再往下看禁用windowsup…

    2022年5月8日
    325
  • java简单的除法运算_Java除法运算的陷阱[通俗易懂]

    java简单的除法运算_Java除法运算的陷阱[通俗易懂]3、求余:和除法差不多。System.out.println(23%4);System.out.println(23%-4);System.out.println(-23%4);System.out.println(23f%4);System.out.println(23d%4);System.out.println(23%4f);System.out.println(23%4d);System….

    2022年6月4日
    40
  • vue文件中引入js_vue中require引入js

    vue文件中引入js_vue中require引入js由于一些演示,需要对编码名称等可快速进行修改,需要页面方便配置。由于build后的vue项目基本已经看不出原样,因此需要创建一个文件,并在打包的时候不会进行编译。vue-cli2.0的作法是在static文件下创建js。vue-cli3.0的写法则是直接在public文件夹下创建js、具体操作如下:1、在public文件夹下创建config.js文件,里面文件的语法是es5,不允许使用浏览器…

    2022年10月8日
    0

发表回复

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

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