Liferay7 BPM门户开发之8: Activiti实用问题集合
1、如何实现审核的上级获取(任务逐级审批)
这个是必备功能,通过Spring的注入+Activiti表达式可以很容易解决。
可参考:
http://blog.csdn.net/sunxing007/article/details/8491552
http://linhongyu.blog.51cto.com/6373370/1656596
2、如何设置流程发起人,并动态在其他任务中使用
通过变量,在启动的时候设置。
activiti里设置流程发起人的功能很绕。
activiti 指定发起人,并作为流程变量在流程中的其他任务中使用,
在流程文件中定义开始事件
<startEvent id="start" activiti:initiator="initiator" /> initiator 作为一个流程变量在其他任务节点中使用
<userTask id="theTask" name="My Task">
<humanPerformer>
<resourceAssignmentExpression>
<formalExpression>${initiator}</formalExpression>
</resourceAssignmentExpression>
</humanPerformer>
</userTask>
发起流程时指定发起人:
identityService.setAuthenticatedUserId("startuser");
runtimeService.startProcessInstanceByKey("simpleProcess");
3、spring帮助TaskListener自动注入依赖
1. 如果想让spring对ExecutionListener实现依赖注入。就要让spring管理对应的bean,再从spring中获取这个bean。关键就是不能自己new一个class,如果你自己new了一个class,spring怎么知道这个class什么时候需要注入?
2. 确认spring管理好bean之后,在actviiti中,使用expression表达式引用这个bean。
不能用这种方式,这种方式就是直接new一个class,创建出的实例不是spring托管的,无法自动注入依赖:
<activiti:executionlistener< span=""><activiti:executionListener class="org.activiti.engine.test.bpmn.event.IntermediateNoneEventTest$MyExecutionListener" event="start" />
要使用expression从spring中获取托管的bean,expression部分写bean的id:
<activiti:executionlistener< span=""><activiti:executionListener delegateExpression="${myExecutionListener}" event="end" />
4、流程图中文乱码
解决方法:设置ProcessEngineConfiguration中的属性,注意版本必须是5.13或以上版本,老版本不支持labelFontName
<property name="activityFontName" value="宋体"/>
<property name="labelFontName" value="宋体"/>
衍生问题:设置了字体之后,图片依然乱码,有两种可能:
- 没有重新部署流程,所以没有重新使用新配置生成图片。
- 没有使用cmd的方式包装生成图片的方法,导致配置没有启用
通过封装cmd的方式调用生成图片的方法:
如果不想用优雅的封装cmd的方法,只能手工初始化Context了。
Context.setProcessEngineConfiguration(processEngine.getProcessEngineConfiguration());
5、在流程运行中指定下一个处理人
前一个节点设置流程变量,completeTask(taskId, map)这样传递进一个变量,叫step3Assignee="nextUserName"
下一个节点设置activiti:assigne="${step3Assignee}",就实现了前一个节点指定后一个节点的负责人
手动设置任务办理人
<usertask id="hrAudit" name="人事审批" activiti:assignee="${hrUserId}"></usertask>
动态指定只要在任务完成的时候传递activiti:assignee属性中的变量即可。
Map<String, Object> variables = new HashMap<String, Object>();
variables.put("hrUserId", hrUserId);
taskService.complete(taskId, variables);
6、activiti如何与现有系统集成
要走的路任重道远:
1.集成用户账号
2.集成组织机构
3.集成权限
4.集成事务
5.集成业务数据
6.集成表单体系
7.集成服务
8.组件服务:人员、组、上级、组织架构通用选择器
7、自定义业务流程关联
定义表单的方式在每个Task标签中定义extensionElements和activiti:formProperty即可,到达这个节点的时候可以通过API读取表单元素。
Activiti官方的例子使用的就是在流程定义中设置每一个节点显示什么样的表单哪些字段需要显示、哪些字段只读、哪些字段必填。
但是这种方式仅仅适用于比较简单的流程,对于稍微复杂或者页面需要业务逻辑的判断的情况就不适用了。
业务和流程关联可以用
startProcessInstanceByKey
其中businessKey就是业务ID,例如要申请请假,那么先填写登记信息,然后(保存+启动流程),因为请假是单独设计的数据表,所以保存后得到实体ID就可以把它传给processInstanceBusinessKey方法启动流程。当需要根据businessKey查询流程的时候就可以通过API查询。
建议数据库冗余设计:在业务表设计的时候添加一列:PROCESS_INSTANCE_ID varchar2(64),在流程启动之后把流程ID更新到业务表中,这样不管从业务还是流程都可以查询到对方!
特别说明: 此方法启动时自动选择最新版本的流程定义。
startProcessInstanceById
javadoc对其说明:
startProcessInstanceById(String processDefinitionId, String businessKey, Map<string,object> variables)
Starts a new process instance in the exactly specified version of the process definition with the given id.
processDefinitionId:这个参数的值可以通过repositoryService.createProcessDefinitionQuery()方法查询,对应数据库:ACT_RE_PROCDEF;每次部署一次流程定义就会添加一条数据,同名的版本号累加。
8、查询我发起的流程
首先要通过setAuthenticatedUserid("lingo")在发起流程之前设置流程发起人。
然后可以通过processEngine.getHistoryService().createHistoricProcessInstanceQuery().starterUserid("lingo").list()
Liferay7 BPM门户开发之8: Activiti实用问题集合的更多相关文章
- Liferay7 BPM门户开发之11: Activiti工作流程开发的一些统一规则和实现原理(完整版)
注意:以下规则是我为了规范流程的处理过程,不是Activiti公司的官方规定. 1.流程启动需要设置启动者,在Demo程序中,“启动者变量”名统一设置为initUserId 启动时要做的: ident ...
- Liferay7 BPM门户开发之7: Activiti中的重要概念和主要数据库结构
流程的人员参与角色: Assignee :签收者(即待办人) Candidate:候选人 Owner:拥有者 Starter:启动者 participant:参与者,包含查阅 流程变量的类型: Str ...
- Liferay7 BPM门户开发之6: Activiti数据库换为mysql
第一步: 在mysql中创建数据库名字叫 'activiti' 执行D:\activiti-5.21.0\database\create下的脚本 第二步: 打开=> apache-tomcat/ ...
- Liferay7 BPM门户开发之5: Activiti和Spring集成
参考文档: https://github.com/jbarrez/spring-boot-with-activiti-examplehttps://github.com/sxyx2008/spring ...
- Liferay7 BPM门户开发之4: Activiti事件处理和监听Event handlers
事件机制从Activiti 5.15开始引入,这非常棒,他可以让你实现委托. 可以通过配置添加事件监听器,也可以通过Runtime API加入注册事件. 所有的事件参数子类型都来自org.activi ...
- Liferay7 BPM门户开发之3: Activiti开发环境搭建
下载地址: http://activiti.org/download.html 源码: https://github.com/Activiti/Activiti 环境准备(检查项): JDK 1.7 ...
- Liferay7 BPM门户开发之10: 通用流程实现从Servlet到Portlet(Part1)
开发目的: 实现通用流程自动化处理(即实现不需要hardcode代码的bpm统一处理后台,仅需要写少量前端html form代码和拖拽设计BPM定义) 既可独立运行或可依托于Liferay或依托其它门 ...
- Liferay7 BPM门户开发之37: Liferay7下的OSGi Hook集成开发
hook开发是Liferay客制扩展的一种方式,比插件灵活,即可以扩展liferay门户,也能对原有特性进行更改,Liferay有许多内置的服务,比如用hook甚至可以覆盖Liferay服务. 可作为 ...
- Liferay7 BPM门户开发之17: Portlet 生命周期
Portlet 生命周期 init() =〉 render() =〉 processAction() =〉 processEvent() =〉 serveResource() =〉destroy() ...
随机推荐
- Element-UI使用指南
原网址:https://blog.csdn.net/u012285967/article/details/53023825 Element-UI是饿了么前端团队推出的一款基于Vue.js 2.0 的桌 ...
- 连续子数组最大和(python)
题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决.但是,如果向量 ...
- NSLog无法使用
iOS/macos 中 #import<foundation/foundation.h> nslog不能用 如果项目中包含c/c++程序代码 将其后缀修改成.m .mm 将项目的build ...
- Initialization of bean failed; nested exception is java.lang.NoClassDefFoundError: javax/jms/JMSContext
参考链接 : https://blog.csdn.net/angus_Lucky/article/details/82811946?utm_source=blogxgwz7 org.springfra ...
- 深入理解JVM(六)类文件结构
6.1 关于类文件 1.class文件的一次编译,到处运行的跨平台性: 2.JVM不止有跨平台性,还有跨语言性,不管是JRuby还是Groovy写出来的程序,只要编译出符合JVM规范的class文件就 ...
- shiro的rememberMe不生效
问题描述:已经设置了map.put("/**", "user"),但是查看网页Cookie没有值. 问题查思路: 1.确定使用UserFilter过滤器,因为只 ...
- [solution] JZOJ-5458 质数
[solution] JZOJ-5458 质数 题面 Description 小X 是一位热爱数学的男孩子,在茫茫的数字中,他对质数更有一种独特的情感.小X 认为,质数是一切自然数起源的地方. 在小X ...
- PMP:5.项目范围管理
项目范围管理包括确保项目做且只做所需的全部工作,以成功完成项目的各个过程. 管理项目范围主要在于定义和控制哪些工作应该包括在项目内,哪些不应该包括在项目内. 核心概念: 规划范围管理:为记录如何定 ...
- [数据清洗]-Pandas 清洗“脏”数据(一)
概要 准备工作 检查数据 处理缺失数据 添加默认值 删除不完整的行 删除不完整的列 规范化数据类型 必要的转换 重命名列名 保存结果 更多资源 Pandas 是 Python 中很流行的类库,使用它可 ...
- 【leetcode】 算法题2 两数相加
问题 给定两个非空链表来表示两个非负整数.位数按照逆序方式存储,它们的每个节点只存储单个数字.将两数相加返回一个新的链表. 你可以假设除了数字 0 之外,这两个数字都不会以零开头. 示例 ...