在常用的ERP系统、OA系统的开发中,工作流引擎是一个必不可少的工具。本项目旨在基于Spring boot这一平台,整合业界流行的工作流引擎Activiti,并建立了两个完整的工作流进行演示:请假OA和采购流程。
其中包含的内容如下:
1.不采用activiti自带的用户、角色功能,因为过于简单,转而自行实现一个用户、角色、权限的三级结构,用户到角色,角色到权限均为多对多映射,持久层框架使用mybatis的collection和association标签嵌套实现;
2.使用默认的用户登录后(用户名xiaomi,密码1234),可看到已部署好的两个流程,请假OA和采购流程,其中,请假OA包含了用户任务、排他网关、起始结束事件,较为简单;采购流程除此之外,还使用了异常结束事件、子流程和边界事件的使用;
3.两个流程均包含了待办任务签收、运行流程进度追踪、已运行完流程历史记录查看的功能,运行流程进度在流程图中以红色标注;
4.使用时,将流程数据和业务数据相分离,使用业务号(businessKey)建立关联流程数据和业务数据的桥梁,使其相互可以访问,业务数据的主键即为业务号;
5.本系统所有表单均使用普通表单,而不是activiti的动态表单和外置表单,这样做是为了分表存放业务数据和流程数据;
6.系统前端采用基于Bootstrap的模板devoops建立。https://github.com/shenzhanwang/devoops
7.起始页面入口:http://localhost:8888/login 使用前,编译(可直接在myeclipse完成):
mvn clean install
- swagger入口:http://localhost:8888/swagger-ui.html
- 新增流程图设计器,将activiti-explorer.war放入Tomcat8.5的webapps目录下,启动Tomcat,访问http://localhost:8080/activiti-explorer ,即可进入登录页面,用户名和密码都是kermit: 点击流程->流程设计工作区->新建模型,填入模型名称,点击创建按钮即可开始流程图设计: 设计完后,可以导出源文件:
- 新增动态菜单权限,通过给不同用户分配不同的角色,使他们看到不同的菜单。
- 请假流程直接分配到具体审批人,只有指定的审批人才能审批。采购流程按照候选者组进行任务签收,只要能拥有相关菜单的权限即可审批。
12.效果图:
- Spring boot整合Mybatis实现增删改查(支持多数据源)
- Struts2,Hibernate,Spring三大框架的整合实现增删改查
- Spring,SpringMVC和Hibernate的整合实现增删改查
- Spring boot整合activiti工作流引擎实现OA开发
- Spring发布与调用REST风格的WebService
- Spring boot整合Axis调用SOAP风格的web服务
- Spring boot整合Apache Shiro实现RBAC权限控制
- 使用Spring security实现RBAC权限控制
- Spring boot整合mongoDB文档数据库实现增删改查
- Spring连接Redis实现缓存
- Spring连接图存数据库Neo4j实现增删改查
- Spring boot整合列存数据库hbase实现增删改查
- Spring平台整合消息队列ActiveMQ实现发布订阅、生产者消费者模型(JMS)
- Spring boot整合消息队列RabbitMQ实现四种消息模式(AMQP)
- Spring boot整合kafka 2.1.0实现大数据消息管道
- Spring boot整合websocket实现即时通讯
- Spring security整合oauth2实现token认证
- Spring boot整合MinIO客户端实现文件管理
- 23种设计模式,源码、注释、使用场景
- 使用ETL工具Kettle的实例
- Git指南和分支管理策略
- 使用数据仓库进行OLAP数据分析(Mysql+Kettle+Zeppelin)
- zookeeper原理、架构、使用场景和可视化
- Spring boot整合Apache dubbo v2.7.5实现分布式服务治理(SOA架构)
包含组件Spring boot v2.2.2+Dubbo v2.7.5+Nacos v1.1.1 效果图
包含组件Nacos+Feign+Gateway+Ribbon+Sentinel+Zipkin 效果图
- 使用jenkins+centos+git+maven搭建持续集成环境自动化部署分布式服务
- 使用docker+compose+jenkins+gitlab+spring cloud实现微服务的编排、持续集成和动态扩容
- 使用Spark进行分布式计算
- Spark SQL做离线计算
- Spark Streaming做实时计算
- Structured Streaming做实时计算
- 使用Flink实现流批一体化的分布式计算
- 搭建高可用nginx集群和Tomcat负载均衡
- 使用mycat实现Mysql数据库的主从复制、读写分离、分表分库、负载均衡和高可用
- Spring boot整合Elastic search实现全文检索和大数据分析
包含组件nacos v1.1.0 + seata v0.7.1 +spring boot dubbo v2.7.5 效果图
包含组件nacos v1.1.0 + seata v0.7.1 +spring cloud alibaba v2.1.0 效果图