springboot2.2 集成 activity6实现请假流程(示例详解)

新手学习记录。写在springboot test 示例  示例代码地址看结尾。后面有带页面的示例。

SpringBoot Test无页面简单示例

员工请假流程

  1. 员工发起申请,附带请假信息(请假几天)
  2. 单位领导审批,如果通过,交付经理审批,不通过,重新申请
  3. 经理审批,如果请假天数不超过三天,经理1审批
  4. 如果请假天数在3-5天,经理3审批
  5. 超过5天,经理2审批
  6. 经理审批通过,流程结束,经理审批不通过,员工重新申请

流程图

代码

activiti.cfg.xml为必须文件且数据库连接正确,否则ProcessEngines.getDefaultProcessEngine()会报空指针。

复制代码
<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

 <!-- Activity 的引擎配置管理器 -->
 <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
 <!-- 指定数据源 -->
 <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/activity?serverTimezone=UTC&amp;characterEncoding=UTF-8" />
 <property name="jdbcDriver" value="com.mysql.cj.jdbc.Driver" />
 <property name="jdbcUsername" value="root" />
 <property name="jdbcPassword" value="111111" />
 <property name="databaseSchemaUpdate" value="true" />
 </bean>
</beans>

测试类

三个方法可合并在一起运行,拆开是自己为了方便查看代码步骤。

1. 先运行deploymentProcess()部署一个流程。

2. 运行startLeaveProcess() 开启流程。

3. 运行getTaskAndComplete()走流程。循环一次性整个流程走完。

package com.blackcat.activity;

import org.activiti.engine.*;
import org.activiti.engine.repository.Deployment;
import org.activiti.engine.runtime.ProcessInstance;
import org.activiti.engine.task.Task;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.HashMap;
import java.util.Map;

/**
 * @Title 申请测试
 * @Description
 * @author zhanghui
 * @date 2020年07月17日 15:06
 * @version V1.0
 * @see
 * @link https://blog.csdn.net/fly_fly_fly_pig/article/details/81700820 参考该博客
 * @since V1.0
 */
@SpringBootTest
class LeaveProcessTest {

 // 获取默认的流程引擎
 private ProcessEngine engine = ProcessEngines.getDefaultProcessEngine();

 // 实例流程id,用来记录流程,以便获取当前任务
 private String processInstanceId;

 // 部署一个流程
 @Test
 void deploymentProcess(){
 RepositoryService rs = engine.getRepositoryService();
 Deployment deploy = rs.createDeployment().addClasspathResource("processes/LeaveProcess.bpmn").deploy();
 rs.createProcessDefinitionQuery().deploymentId(deploy.getId()).singleResult();
 }

 // 开启流程
 @Test
 void startLeaveProcess(){
 // 获取runtimeservice对象
 RuntimeService runtimeService = engine.getRuntimeService();

 // 根据流程key值,获取流程
 String processKey = "leaveProcess";

 // 将信息加入map,以便传入流程中
 Map<String, Object> variables = new HashMap<>();
 variables.put("employeeName", "张三");
 variables.put("day",10);

 // 开启流程
 ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(processKey, variables);
 // 将得到的实例流程id值赋给之前设置的变量
 processInstanceId = processInstance.getId();
 System.out.println("流程开启成功.......实例流程id:"+processInstanceId);
 }

 // 开始走流程
 // 1.获取当前任务,并且完成
 @Test
 void getTaskAndComplete(){
// processInstanceId = "12501";
 // 获取taskservice实例
 TaskService taskService = engine.getTaskService();

 // 开始进行流程
 while(engine.getRuntimeService()
 .createProcessInstanceQuery()// 获取查询对象
 .processInstanceId(processInstanceId)// 根据id查询流程实例
 .singleResult()// 获取查询结果,如果为空,说明这个流程已经执行完毕,否则,获取任务并执行
 !=null){
 Task task = taskService.createTaskQuery()// 创建查询对象
  .processInstanceId(processInstanceId)// 通过流程实例id来查询当前任务
  .singleResult();// 获取单个查询结果
 String taskName = task.getName();

 if(taskName.equals("发起申请")){// 职员节点
 completeEmployeeTask(task);
 }else if(taskName.equals("领导审批")){// 领导节点
 completeLeaderTask(task);
 }else{// 经理节点
 completeJingliTask(task);
 }
 }

 System.out.println("审核结束..........");
 }

 // 职员提交申请
 void completeEmployeeTask(Task task){
 // 获取任务id
 String taskId = task.getId();

 // 完成任务
 engine.getTaskService().complete(taskId);
 System.out.println("职员已经提交申请.......");
 }

 // 领导审批
 void completeLeaderTask(Task task){
 // 获取任务id
 String taskId = task.getId();

 // 领导意见
 Map<String, Object> variables = new HashMap<>();
 variables.put("leaderResult", 1);

 // 完成任务
 engine.getTaskService().complete(taskId, variables);
 System.out.println("领导审核完毕........");

 }

 // 经理审批
 void completeJingliTask(Task task){
 // 获取任务id
 String taskId = task.getId();
 String name = task.getName();

 // 经理意见
 // 领导意见和经理意见,用0和1表示,0表示未通过,1表示通过
 // 任一环节设置不同意,陷入死循环
 Map<String, Object> variables = new HashMap<>();
 variables.put("result", 1);

 // 完成任务
 engine.getTaskService().complete(taskId, variables);
 System.out.println("经理审核完毕........,审核经理:"+name);

 }

参考博客:https://www.jb51.net/article/191910.htm

源码地址:https://gitee.com/kylin_lawliet/springboot-demos/tree/master/springboot-activity3

SpringBoot含页面完整示例

流程方面与上方示例代码差不多,加了页面与mybatis plus。就不贴上代码,直接放示例代码吧。

流程图

效果图

源码地址:https://gitee.com/kylin_lawliet/springboot-demos/tree/master/springboot-activity4

到此这篇关于springboot2.2 集成 activity6实现请假完整流程示例详解的文章就介绍到这了,更多相关springboot2.2集成activity6请假内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解Android Activity中的几种监听器和实现方式

    Activity 在Activity中,使用findViewById(int resId)方法与布局中的控件绑定 View常用事件接口 View的事件监听是指用户与应用交互,当用户对View进行点击.长按.触摸.移动等动作时.程序对这些动作进行处理 OnClickListener    点击View时的监听 OnLongClickListener  长按View时的监听 OnTouchListener   触摸View时的监听 1.android系统中,OnClickListener 是一种处理

  • 详解Android封装一个全局的BaseActivity

    1.前言 对于一个Android开发者来说,每一个页面都继承一个单独的系统Activity,有时候会带来很多不必要的困扰.比如:每一个页面会有重复的代码,阅读起来麻烦:每一次写新的页面功能总要打开原来的页面代码拷贝一部分过来:有时候代码调试排查问题也不方便等等. 如果你的项目里面没有将Activity都继承自一个自己封装的BaseActivity.或者针对自己封装的BaseActivity觉得还不够完善的,这篇博客可能会对你有帮助! 2.特点 封装:将所有Activity都用到的一部分代码封装到

  • Android非异常情况下的Activity生命周期分析

    Activity非异常情况下的生命周期是指,用户正常参与UI交互的情况下,Activity所经过的生命周期的改变:一般情况下,Activity会经过以下几个生命周期. 1.OnCreate(): 表示Activity正在创建,这个是生命周期的第一个方法,该方法只调用一次,在这个方法中,一般做变量初始化的操作,例如绑定一个Button控件的Id等. 2.onRestart(): 表示Activity正在重新启动,一般情况下,如果最前面的Activity从不可见状态变为可见状态时,onRestart

  • Android利用startActivityForResult返回数据到前一个Activity

    在Android里面,从一个Activity跳转到另一个Activity.再返回,前一个Activity默认是能够保存数据和状态的.但这次我想通过利用startActivityForResult达到相同的目的,虽然看起来变复杂了,但可以探索下startActivityForResult背后的原理和使用注意事项. 要实现的功能如下: 从Activity A将数据传到Activity B,再从Activity B中获取数据后,再传回Activity A.在Activity B中添加一个"回到上一页&

  • 详解Android Activity的启动流程

    前言 activity启动的流程分为两部分:一是在activity中通过startActivity(Intent intent)方法启动一个Activity:二是我们在桌面通过点击应用图标启动一个App然后显示Activity:第二种方式相较于第一种方式更加全面,所以本文会以第二种流程来分析. 简要 我们手机的桌面是一个叫做Launcher的Activity,它罗列了手机中的应用图标,图标中包含安装apk时解析的应用默认启动页等信息.在点击应用图标时,即将要启动的App和Launcher.AMS

  • 通过实例解析android Activity启动过程

    注:只是说明启动activity的过程(ActivityThread如何与ActivityManagerService简称AmS进行进程间通信调用全过程),不解析android从zygote(受精卵)到整个系统服务的启动 具体来讲,启动activity的方式有以下几种: 在应用程序中startActivity()或startActivityForResult()方法启动指定activity 在HOME(桌面)程序中单击应用图标,启动新的activity 按"BACK"键结束当前acti

  • Android用tabhost实现 界面切换,每个界面为一个独立的activity操作

    我就废话不多说了,大家还是直接看代码吧~ // 要extends TabActivity public class Main_activity extends TabActivity { private TabHost tabHost;// 建立Tabhost控件 protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); tabHost = getTabHost(); addT

  • Android Activity的4种启动模式图文介绍

    前言 记得第一次探讨Activity的启动模式,是在2017年8月份,那个时候对一年后走出校门的未来很是憧憬,时间真快,已经毕业四个月,工作和生活也都趋于稳定. 一.小前言 相信很多人和我一样,在初学Android甚至初入职场的时候不了解Acticity的启动模式,或者为了面试刷题刷到了,但并不理解启动模式的作用,以及如何正确的使用启动模式而不是所有的都是用默认模式. 二.Activity启动模式简介 Activity有四种启动模式,standard.singleTop.singleTask.s

  • Android IPC机制ACtivity绑定Service通信代码实例

    Binder通信过程类似于TCP/IP服务连接过程binder四大架构Server(服务器),Client(客户端),ServiceManager(DNS)以及Binder驱动(路由器) 其中Server,Client,ServiceManager运行于用户空间,驱动运行于内核空间.这四个角色的关系和互联网类似:Server是服务器,Client是客户终端,SMgr是域名服务器(DNS),驱动是路由器. book.java package com.example.android_binder_t

  • Android实现左滑退出Activity的完美封装

    1:定义一个自己的父级容器,让它继承自一个布局(LinearLayout.RelativeLayout都可以) public class SildingFinishLayout extends RelativeLayout implements View.OnTouchListener { /** * SildingFinishLayout布局的父布局 */ private ViewGroup mParentView; /** * 处理滑动逻辑的View */ private View touc

  • c# WPF中System.Windows.Interactivity的使用

    背景 在我们进行WPF开发应用程序的时候不可避免的要使用到事件,很多时候没有严格按照MVVM模式进行开发的时候习惯直接在xaml中定义事件,然后再在对应的.cs文件中直接写事件的处理过程,这种处理方式写起来非常简单而且不用过多地处理考虑代码之间是否符合规范,但是我们在写代码的时候如果完全按照WPF规范的MVVM模式进行开发的时候就应该将相应的事件处理写在ViewModel层,这样整个代码才更加符合规范而且层次也更加清楚,更加符合MVVM规范. 常规用法 1 引入命名空间 通过在代码中引入Syst

随机推荐