activiti自定义流程之Spring整合activiti-modeler5.16实例(七):任务列表展示

简介: <span style="font-family:Arial; font-size:14px; line-height:26px"></span><span style="font-family:Arial; font-size:14px; line-height:26px">注:(1)环境搭建:<a target="_blank" href="http://blog.csdn.net/t
注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建
        (2)创建流程模型:activiti自定义流程之Spring整合activiti-modeler5.16实例(二):创建流程模型 
        (3)流程模型列表展示:activiti自定义流程之Spring整合activiti-modeler5.16实例(三):流程模型列表展示
        (4)部署流程定义:activiti自定义流程之Spring整合activiti-modeler5.16实例(四):部署流程定义

        (5)流程定义列表:activiti自定义流程之Spring整合activiti-modeler5.16实例(五):流程定义列表

        (6)启动流程:activiti自定义流程之Spring整合activiti-modeler5.16实例(六):启动流程



1.通过上一节的操作,可以知道流程启动以后会同时生成一个流程实例和用户任务,这个用户任务保存在act_ru_task和act_hi_task表中,从表明可以看出ru是runtime,hi是history。但是需要注意的是,和操作流程使用的service不同,操作正在发生任务不是使用runtimeService,而是专门的taskService。
2.后台业务代码,
  (1)自定义的任务实体类

package model;
import java.util.Date;
public class TaskModel {
	private String id;
	private String name;
	private String processInstanceId;
	private String assignee;
	private Date createTime;
	private String nextPerson;
	private String cause;
	private String content;
	private String taskType;
	private String processKey;
	private String processDefId;

	public String getTaskType() {
		return taskType;
	}

	public void setTaskType(String taskType) {
		this.taskType = taskType;
	}

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getProcessInstanceId() {
		return processInstanceId;
	}

	public void setProcessInstanceId(String processInstanceId) {
		this.processInstanceId = processInstanceId;
	}

	public String getAssignee() {
		return assignee;
	}

	public void setAssignee(String assignee) {
		this.assignee = assignee;
	}

	public Date getCreateTime() {
		return createTime;
	}

	public void setCreateTime(Date createTime) {
		this.createTime = createTime;
	}

	public String getNextPerson() {
		return nextPerson;
	}

	public void setNextPerson(String nextPerson) {
		this.nextPerson = nextPerson;
	}

	public String getCause() {
		return cause;
	}

	public void setCause(String cause) {
		this.cause = cause;
	}

	public String getContent() {
		return content;
	}

	public void setContent(String content) {
		this.content = content;
	}

	public String getProcessKey() {
		return processKey;
	}

	public void setProcessKey(String processKey) {
		this.processKey = processKey;
	}

	public String getProcessDefId() {
		return processDefId;
	}

	public void setProcessDefId(String processDefId) {
		this.processDefId = processDefId;
	}

	@Override
	public String toString() {
		return "TaskModel [id=" + id + ", name=" + name
				+ ", processInstanceId=" + processInstanceId + ", assignee="
				+ assignee + ", createTime=" + createTime + ", nextPerson="
				+ nextPerson + ", cause=" + cause + ", content=" + content
				+ ", taskType=" + taskType + ", processKey=" + processKey
				+ ", processDefId=" + processDefId + "]";
	}
}



(2)业务逻辑:查询任务使用taskService调用相关的方法来完成,可以根据特定的条件,也可以不加条件查询所有。可以返回task为元素的list,也可以返回单独的task对象,但是需要注意的是,如果要返回单独的task对象,则必须确定返回值是唯一的对象,否则就会抛出异常。下边的例子中,我是根据当前登陆的用户名来查询出对应的所有task:
/**
	 * @throws XMLStreamException
	 *             查询个人任务
	 * 
	 * @author:tuzongxun
	 * @Title: findTask
	 * @param @return
	 * @return Object
	 * @date Mar 17, 2016 2:44:11 PM
	 * @throws
	 */
	@RequestMapping(value = "/findTask.do", method = RequestMethod.POST, produces = "application/json;charset=utf-8")
	@ResponseBody
	public Object findTask(HttpServletRequest req) throws XMLStreamException {
		Map<String, Object> map = new HashMap<String, Object>();
		boolean isLogin = this.isLogin(req);
		if (isLogin) {
			List<TaskModel> taskList = new ArrayList<TaskModel>();
			HttpSession session = req.getSession();
			String assginee = (String) session.getAttribute("userName");
			List<Task> taskList1 = taskService.createTaskQuery()
					.taskAssignee(assginee).list();
			if (taskList1 != null && taskList1.size() > 0) {
				for (Task task : taskList1) {
					TaskModel taskModel = new TaskModel();
					taskModel.setAssignee(task.getAssignee());
					taskModel.setCreateTime(task.getCreateTime());
					taskModel.setId(task.getId());
					taskModel.setName(task.getName());
					taskModel.setProcessInstanceId(task.getProcessInstanceId());
					taskModel.setProcessDefId(task.getProcessDefinitionId());
					// 获取流程变量
					Map<String, Object> variables = runtimeService
							.getVariables(task.getProcessInstanceId());
					Set<String> keysSet = variables.keySet();
					Iterator<String> keySet = keysSet.iterator();
					while (keySet.hasNext()) {
						String key = keySet.next();
						if (key.endsWith("cause")) {
							taskModel.setCause((String) variables.get("cause"));
						} else if (key.endsWith("content")) {
							taskModel.setContent((String) variables
									.get("content"));
						} else if (key.endsWith("taskType")) {
							taskModel.setTaskType((String) variables
									.get("taskType"));
						} else if (!assginee.equals(variables.get(key))) {
							// 想办法查询是否还有下一个任务节点
							Iterator<FlowElement> iterator = this.findFlow(task
									.getProcessDefinitionId());
							while (iterator.hasNext()) {
								FlowElement flowElement = iterator.next();
								String classNames = flowElement.getClass()
										.getSimpleName();
								if (classNames.equals("UserTask")) {
									UserTask userTask = (UserTask) flowElement;
									String assginee11 = userTask.getAssignee();
									String assginee12 = assginee11.substring(
											assginee11.indexOf("{") + 1,
											assginee11.indexOf("}"));
									String assignee13 = (String) variables
											.get(assginee12);
									if (assginee.equals(assignee13)) {
										// 看下下一个节点是什么
										iterator.next();
										FlowElement flowElement2 = iterator
												.next();
										String classNames1 = flowElement2
												.getClass().getSimpleName();
										// 设置下一个任务人
										if (!(classNames1.equals("EndEvent"))) {
											UserTask userTask2 = (UserTask) flowElement2;
											String assginee21 = userTask2
													.getAssignee();
											String assginee22 = assginee21
													.substring(
															assginee21
																	.indexOf("{") + 1,
															assginee21
																	.indexOf("}"));
											String assignee23 = (String) variables
													.get(assginee22);
											taskModel.setNextPerson(ToolUtils
													.isEmpty(assignee23));
										}
									}


								}
							}
							// //////////
						}
					}
					taskList.add(taskModel);
				}
			}
			map.put("isLogin", "yes");
			map.put("userName",
					(String) req.getSession().getAttribute("userName"));
			map.put("result", "success");
			map.put("data", taskList);
		} else {
			map.put("isLogin", "no");
		}
		return map;
	}




3.angular js前台代码(前台只是做简单的展示,不多讲):
  (1)app.js中配置路由:
   
  
 $stateProvider  
   .state('taskList', {  
   url: "/taskList",  
   views: {  
      'view': {  
       templateUrl: 'activi_views/taskList.html',  
       controller: 'taskCtr'  
      }  
   }  
  });  



  (2)逻辑相关代码:

   
  angular.module('activitiApp')  
.controller('taskCtr', ['$rootScope','$scope','$http','$location','$state', function($rootScope,$scope,$http,$location,$state){  
$scope.init=function(){
        $http.post("./findTask.do").success(function(result) {
        	if(result.isLogin==="yes"){
        	console.log(result.data); 
        	$rootScope.userName=result.userName;
    	    $scope.taskList=result.data;
        	}else{
        		$location.path("/login");
        	}
        });
}    
        $scope.completeTaskTo=function(task){
        	console.log(task);
        	$rootScope.task=task;
        	//$location.path("/completeTaskTo");
        	$location.path("/completeTaskTo1");
        }
      
  
}])  



4.对应的填写相关信息的页面:

<div id="logdiv1" ng-init="init();">  
   <p style="font-size:22px;margin-top:10px">当前任务列表</p>
   <center> 
   <table border="1px" style="width:87%;font-size:14px;text-align:center;margin-top:1px;margin-left:2px;position:relative;float:left;" cellSpacing="0px" cellPadding="0px">
      <tr style="background-color:#ccc">
         <td>类型</td>
         <td>ID</td>
         <td>NAME</td>
         <td>ProcessIntanceId</td>
         <td>ProcessDefId</td>
         <td>创建时间</td>
         <td>申请人</td>
         <td>受理人</td>
         <td>申请原因</td>
         <td>申请内容</td>
         <td>操 作</td>
      </tr>
      <tr ng-repeat="task in taskList | orderBy:'id'" >
         <td>{{task.taskType}}</td>
         <td>{{task.id}}</td>
         <td>{{task.name}}</td>
         <td>{{task.processInstanceId}}</td>
         <td>{{task.processDefId}}</td>
         <td>{{task.createTime | date:"yyyy-MM-dd HH:mm:ss"}}</td>
         <td>{{task.assignee}}</td>
         <td>{{task.nextPerson}}</td>
         <td>{{task.cause}}</td>
         <td>{{task.content}}</td>
         <td><a href="script:;" ng-click="completeTaskTo(task)">完成任务</a> 
         </td>
      </tr>
   </table>  
   </center> 
</div>  
 


目录
相关文章
|
6天前
|
IDE Java 应用服务中间件
spring boot 启动流程
Spring Boot 启动流程简介: 在使用 Spring Boot 之前,启动 Java Web 应用需要配置 Web 容器(如 Tomcat),并将应用打包放入容器目录。而使用 Spring Boot,只需运行 main() 方法即可启动 Web 应用。Spring Boot 的核心启动方法是 SpringApplication.run(),它负责初始化和启动应用上下文。 主要步骤包括: 1. **应用启动计时**:使用 StopWatch 记录启动时间。 2. **打印 Banner**:显示 Spring Boot 的 LOGO。 3. **创建上下文实例**:通过反射创建
|
2月前
|
XML Java 数据格式
使用idea中的Live Templates自定义自动生成Spring所需的XML配置文件格式
本文介绍了在使用Spring框架时,如何通过创建`applicationContext.xml`配置文件来管理对象。首先,在resources目录下新建XML配置文件,并通过IDEA自动生成部分配置。为完善配置,特别是添加AOP支持,可以通过IDEA的Live Templates功能自定义XML模板。具体步骤包括:连续按两次Shift搜索Live Templates,配置模板内容,输入特定前缀(如spring)并按Tab键即可快速生成完整的Spring配置文件。这样可以大大提高开发效率,减少重复工作。
使用idea中的Live Templates自定义自动生成Spring所需的XML配置文件格式
|
2月前
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
|
2月前
|
NoSQL Java Redis
Spring Boot 自动配置机制:从原理到自定义
Spring Boot 的自动配置机制通过 `spring.factories` 文件和 `@EnableAutoConfiguration` 注解,根据类路径中的依赖和条件注解自动配置所需的 Bean,大大简化了开发过程。本文深入探讨了自动配置的原理、条件化配置、自定义自动配置以及实际应用案例,帮助开发者更好地理解和利用这一强大特性。
147 14
|
3月前
|
安全 Java 应用服务中间件
如何将Spring Boot应用程序运行到自定义端口
如何将Spring Boot应用程序运行到自定义端口
111 0
|
27天前
|
XML Java 应用服务中间件
Spring Boot 两种部署到服务器的方式
本文介绍了Spring Boot项目的两种部署方式:jar包和war包。Jar包方式使用内置Tomcat,只需配置JDK 1.8及以上环境,通过`nohup java -jar`命令后台运行,并开放服务器端口即可访问。War包则需将项目打包后放入外部Tomcat的webapps目录,修改启动类继承`SpringBootServletInitializer`并调整pom.xml中的打包类型为war,最后启动Tomcat访问应用。两者各有优劣,jar包更简单便捷,而war包适合传统部署场景。需要注意的是,war包部署时,内置Tomcat的端口配置不会生效。
201 17
Spring Boot 两种部署到服务器的方式
|
27天前
|
Dart 前端开发 JavaScript
springboot自动配置原理
Spring Boot 自动配置原理:通过 `@EnableAutoConfiguration` 开启自动配置,扫描 `META-INF/spring.factories` 下的配置类,省去手动编写配置文件。使用 `@ConditionalXXX` 注解判断配置类是否生效,导入对应的 starter 后自动配置生效。通过 `@EnableConfigurationProperties` 加载配置属性,默认值与配置文件中的值结合使用。总结来说,Spring Boot 通过这些机制简化了开发配置流程,提升了开发效率。
59 17
springboot自动配置原理
|
1月前
|
XML JavaScript Java
SpringBoot集成Shiro权限+Jwt认证
本文主要描述如何快速基于SpringBoot 2.5.X版本集成Shiro+JWT框架,让大家快速实现无状态登陆和接口权限认证主体框架,具体业务细节未实现,大家按照实际项目补充。
80 11
|
1月前
|
缓存 安全 Java
Spring Boot 3 集成 Spring Security + JWT
本文详细介绍了如何使用Spring Boot 3和Spring Security集成JWT,实现前后端分离的安全认证概述了从入门到引入数据库,再到使用JWT的完整流程。列举了项目中用到的关键依赖,如MyBatis-Plus、Hutool等。简要提及了系统配置表、部门表、字典表等表结构。使用Hutool-jwt工具类进行JWT校验。配置忽略路径、禁用CSRF、添加JWT校验过滤器等。实现登录接口,返回token等信息。
344 12
|
2月前
|
Java 数据库连接 Maven
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
自动装配是现在面试中常考的一道面试题。本文基于最新的 SpringBoot 3.3.3 版本的源码来分析自动装配的原理,并在文未说明了SpringBoot2和SpringBoot3的自动装配源码中区别,以及面试回答的拿分核心话术。
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)