PHP实现流程管理功能
核心逻辑:流程管理,在各种系统中扮演很重要的地位,可以把设定好的流程放入系统中,规定好几个节点,只要所有节点都通过,就可以通过。
建立四张数据库表:




1.我们首先做一个新建流程页面 flow.php,先把节点做好
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="bootstrap/js/jquery-1.11.2.min.js"></script>
</head>
<body>
<h2>管理员新建流程</h2>
<div>请选择人员:
<select id="users" name="users">
<?php
session_start();
require_once "./DBDA.class.php";
$db = new DBDA();
$sql = "select * from users";
$arr = $db->query($sql,0);
foreach($arr as $v){
echo "<option value='{$v[0]}'>{$v[2]}</option>";
}
?>
</select>
<input type="button" value="添加" id="add" />
</div>
<br />
<div>
<?php
if(empty($_SESSION["jd"])){
echo "还未添加节点人员!";
}else{
$arr = $_SESSION["jd"];//数组形式存在
foreach($arr as $k=>$v){//遍历索引(顺序)和名称
$sql = "select name from users where uid='{$v}'";
$name = $db->StrQuery($sql,0);//查一个(一维数组)
echo "<div>{$k}--{$name}--<input type='button' value='删除' class='del' code='{$k}' /></div>";
//根据索引删除相应节点人员
}
}
?>
</div>
<br />
<div>请输入流程名称:
<input type="text" id="name" />
</div>
<br />
<input type="button" value="新建" id="addbtn" />
</body>
<script>
//添加节点按钮加点击
$("#add").click(function(){
var uid = $("#users").val();
$.ajax({
url:"flowchuli.php",
type:"POST",
data:{uid:uid,type:0},
dataType:"TEXT",
success:function(){
window.location.href = "flow.php";
}
});
})
//给删除按钮加点击
$(".del").click(function(){
var k = $(this).attr("code");//获取索引属性
$.ajax({
url:"flowchuli.php",
type:"POST",
data:{k:k,type:1},
dataType:"TEXT",
success:function(){
window.location.href = "flow.php";
}
});
})
//给保存按钮加点击
$("#addbtn").click(function(){
var name = $("#name").val();
$.ajax({
url:"flowchuli.php",
type:"POST",
data:{name:name,type:2},
dataType:"TEXT",
success:function(){
alert("添加成功!");
}
});
})
</script>
</html>
2.做新建流程页面的处理页面flowchuli.php
<?php
session_start();
require_once "./DBDA.class.php";
$db = new DBDA();
$type = $_POST["type"];
switch($type){
case 0:
$uid = $_POST["uid"];
if(empty($_SESSION["jd"])){//暂存节点
$arr = array($uid);//新造数组
$_SESSION["jd"] = $arr;//存入session
}else{
$arr = $_SESSION["jd"];//取数组
$arr[] = $uid;//追加变量到数组
$_SESSION["jd"] = $arr;
}
break;
case 1:
$k = $_POST["k"];
$arr = $_SESSION["jd"];
unset($arr[$k]);
$arr = array_values($arr);//重新对数组进行排序,有返回值接收
$_SESSION["jd"] = $arr;
break;
case 2:
$name = $_POST["name"];
$code = time();//自动生成
$sql = "insert into flow values('{$code}','{$name}')";//流程表
$db->query($sql);
//流程节点表
$arr = $_SESSION["jd"];
foreach($arr as $k=>$v){
$sql = "insert into flowpath values(0,'{$code}','{$v}',{$k})";
$db->query($sql);
}
break;
}
效果如图:
点击选择节点人员可以从数据库调所有人员名单,现在把李四,马七和张三放入流程中,做一个请假流程:



注意:Code必须用varchar,不能用time,因为在上面用了时间戳
3.现在我们在做一个登陆用户页面flowlogin.php,提交请假流程的所有步骤:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="bootstrap/js/jquery-1.11.2.min.js"></script>
<script src="bootstrap/js/bootstrap.min.js"></script>
<link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css"/>
</head>
<style>
.title{
margin-left: 600px;
margin-top: 150px;
}
.quanju{
margin-left: 450px;
margin-top: -180px;
}
.name,.pwd{
max-width: 120px;
}
.yangshi1{
margin-top: 200px;
}
</style>
<body>
<form class="form-horizontal" role="form">
<h3 class="title">用户登录</h3>
<div class="quanju">
<div class="form-group yangshi1">
<label for="firstname" class="col-sm-2 control-label">用户名:</label>
<div class="col-sm-10">
<input type="text" class="form-control name" id="uid" placeholder="请输入用户名">
</div>
</div>
<div class="form-group yangshi2">
<label for="lastname" class="col-sm-2 control-label">密码:</label>
<div class="col-sm-10">
<input type="text" class="form-control pwd" id="pwd" placeholder="请输入密码">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<div class="checkbox">
<label>
<input type="checkbox">
保存密码 </label>
<label>
<input type="checkbox">
下次自动登录 </label>
</div>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="button" id="login" class="btn btn-warning" value="登录" >
登录
</button> </div>
</div>
</div>
</form>
</body>
<script>
//登录按钮的点击事件
$("#login").click(function(){
var uid = $("#uid").val();
var pwd = $("#pwd").val();
$.ajax({
type:"post",
url:"flowloginchuli.php",
data:{uid:uid,pwd:pwd},
dataType:"TEXT",
success:function(data){
if(data.trim()=="OK"){
window.location.href="flowmain.php";
}else{
alert("用户名或密码有误!");
}
}
});
})
</script>
</html>
4.登录后跳转的主页面flowmain.php
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <h2>主页面</h2> <a href="flowfq.php">发起流程</a> <a href="flowsh.php">审核流程</a> </body> </html>
5.发起流程页面flow.php
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="bootstrap/js/jquery-1.11.2.min.js"></script>
</head>
<body>
<h2>发起流程</h2>
<form action="flowfqchuli.php" method="post">
请选择流程:
<select name="flow">
<?php
require_once "./DBDA.class.php";
$db = new DBDA();
$sql = "select * from flow";
$arr = $db->query($sql,0);
foreach($arr as $v){
echo "<option value='{$v[0]}'>{$v[1]}</option>";
}
?>
</select>
<br />
<br />
请输入内容:
<textarea name="content"></textarea>
<br />
<br />
<input type="submit" value="确定" />
</form>
</body>
</html>
6.做发起流程的处理页面flowfq.php
<?php
session_start();
require_once "./DBDA.class.php";
$db = new DBDA(); $code = $_POST["flow"];
$uid = $_SESSION["uid"];
$content = $_POST["content"];
$time = date("Y-m-d H:i:s");
$sql = "insert into userflow values(0,'{$code}','{$uid}','{$content}',0,'{$time}',0)";
$db->query($sql);
header("location:flowmain.php");
7.审核页面flowsh.php
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="bootstrap/js/jquery-1.11.2.min.js"></script>
<script src="bootstrap/js/bootstrap.min.js"></script>
<link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div><h2>审核页面</h2>
<table class="table table-bordered">
<thead>
<tr>
<th>流程代号</th>
<th>发起人</th>
<th>发起内容</th>
<th>通过状态</th>
<th>发起时间</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<?php
session_start();
$uid = $_SESSION["uid"];
require_once "./DBDA.class.php";
$db = new DBDA();
//相关子查询(用到父查询的数据)(父查询卡在某一位置)
$sql = "select * from userflow a where towhere>=(select b.order from flowpath b where b.code=a.code and b.uid='{$uid}')";
$arr = $db->query($sql,0);
foreach($arr as $v){
//$v[6];//流程走到的位置towhere
//$v[1];//利用代号和session中存的name查询order
$sql = "select order from flowpath where code='{$v[1]}' and uid='{$uid}'";
$order = $db->StrQuery($sql,0);//该人员在流程中的次序
$str = "";
if($v[6]==$order){ //传主键值
$str = "<a href='flowtgchuli.php?ids={$v[0]}'>通过</a>";
}else{
$str = "<span style='color:green'>已通过</span>";
}
echo "<tr>
<th>{$v[1]}</th>
<th>{$v[2]}</th>
<th>{$v[3]}</th>
<th>{$v[4]}</th>
<th>{$v[5]}</th>
<th>{$str}</th>
</tr>";
}
?>
</tbody>
</table>
</div>
</body>
</html>
8.做审核页面的处理页面flowshchuli.php
<?php
session_start();
$uid = $_SESSION["uid"];
require_once "./DBDA.class.php";
$db = new DBDA(); $ids = $_GET["ids"];
$sql = "update userflow set towhere=towhere+1 where ids='{$ids}'";
$db->query($sql);
//判断;流程是否结束(使用相关子查询)
$swc = "update userflow a set isok=1 where ids='{$ids}' towhere>=(select count(*) from flowpath b where b.code=a.code)";
header("location:flowsh.php");
流程效果如图:
李四的页面:
点击通过后:
数据库:towhere变成1后结束流程

接着该马七:
然后是张三:
数据库:isok变成1后结束流程

PHP实现流程管理功能的更多相关文章
- 流程管理软件(BPM)功能简介
易协流程管理系统实现将人为控制的业务活动,通过信息化手段实现系统控制,降低人为控制管理的风险以及促进企业的各项决策方针的顺利实施. 系统目标: 实现管理的规范化.制度化.程序化: 帮助企业将内控制度流 ...
- 熊乐:H3 BPM为加速企业流程管理提供源动力
近日,在北京·金隅喜来登酒店,H3 BPM以"让天下没有难用的流程"为主题,正式发布H3 BPM10.0版本.全新的业务流程管理系统在易用性方面大大提升,并且全面支持Java与.N ...
- 从国内流程管理软件市场份额看中国BPM行业发展
随着互联网+.中国制造2025.工业4.0等国家战略的支持与引导,企业在数字经济时代的信息化表现惊人,越来越多企业认识到,对于企业的发展来说,信息自动化远远还不够,企业的战略.业务和IT之间需保持高度 ...
- RDIFramework.NET V3.3 Web版新增报表管理功能模块-重量级实用功能
功能描述 在RDIFramework.NET V3.3 Web版本新增了全新的报表管理功能模块,非常实用的功能,重量级推荐.主要用于对日常常用的报表做定制展示.可以自动发布到模块(就可授权给指定资源访 ...
- 用svg做流程管理
说起流程管理这个功能,如果没有个动态图配合显示,简直就是太没有客户体验感了.就比如说请假流程吧,流程走到哪一步了,流程走向过程中都那些人审批的,审批的结果等等,如果就来个列表,也不是说不行,就是觉得太 ...
- 网络Devops探索与实践 流程管理分析师
https://mp.weixin.qq.com/s/OKLiDi78uB8ZkPG2kUVxvA 网络Devops探索与实践 王镇 鹅厂网事 2020-09-23 9月16日举办的2020 ODC ...
- .Net Core MVC 网站开发(Ninesky) 2.2、栏目管理功能-System区域添加
在asp或asp.net中为了方便网站的结构清晰,通常把具有类似功能的页面放到一个文件夹中,用户管理功能都放在Admin文件夹下,用户功能都放在Member文件夹下,在MVC中,通常使用区域(Area ...
- 解析大型.NET ERP系统 通用附件管理功能
大型系统具备一个通用的附件管理功能,对于单据中无法清晰表达的字段,用一个附件图片或附件文档表示是最好的方法了.比如物料清单附加一张CAD图纸,销售订单评审功能中附加客户的各种表格,通用附件功能对系统起 ...
- C#开发微信门户及应用(25)-微信企业号的客户端管理功能
我们知道,微信公众号和企业号都提供了一个官方的Web后台,方便我们对微信账号的配置,以及相关数据的管理功能,对于微信企业号来说,有通讯录中的组织架构管理.标签管理.人员管理.以及消息的发送等功能,其中 ...
随机推荐
- 20165223《Java程序设计》第七周Java学习总结
教材学习内容总结 第11章-JDBC与MySQL数据库 要点 MySQL数据库管理系统 连接MySQL数据库 查询操作(基础) 更新.添加.删除(基础) 预处理语句(重点) 通用查询(难点) 事务 笔 ...
- Duplicate entry 'xxx' for key 'xxx'
插入数据的时候 报错,Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplic ...
- BZOJ 1143: [CTSC2008]祭祀river(最大独立集)
题面: https://www.lydsy.com/JudgeOnline/problem.php?id=1143 一句话题意:给一个DAG(有向无环图),求选出尽量多的点使这些点两两不可达,输出点个 ...
- 200行Go代码实现自己的区块链——区块生成与网络通信
go启动后,可以用telnet登录访问. 注意端口配置写在.env里面. 源码:https://github.com/mycoralhealth/blockchain-tutorial/tree/ma ...
- 基于Jenkins,docker实现自动化部署(持续交互)
前言 随着业务的增长,需求也开始增多,每个需求的大小,开发周期,发布时间都不一致.基于微服务的系统架构,功能的叠加,对应的服务的数量也在增加,大小功能的快速迭代,更加要求部署的快速化,智能化.因此 ...
- UOJ176 新年的繁荣
题目链接 Boruvka生成树算法 \(Boruvka\)算法就是先把每个点看作一个联通块,然后不断在联通块之间找最优的边进行合并.因为每次联通块的数量最少缩小一半.所以合并次数是\(log\)的 先 ...
- pytest 7 assert断言
前言:断言是自动化最终的目的,一个用例没有断言,就失去了自动化测试的意义了. 断言用到的是 assert关键字.之前的介绍,有的测试方法中其实用到了assert断言.简单的来说,就是预期的结果去和实际 ...
- c#Linq联合查询
public void Test2() { var queryResult1 = from e in empArray from l in empLevelArray select new { e, ...
- [HNOI2003]消防局的设立 树形dp // 贪心
https://www.luogu.org/problemnew/show/P2279 一开始就想到了贪心的方法,不过一直觉得不能证明. 贪心的考虑是在深度从深到浅遍历每个结点的过程中,对于每个没有覆 ...
- C#设计模式(1)——简单工厂模式
1.什么是简单工厂 现实中的工厂负责生产产品,顾名思义,编程中的简单工厂就是一个生产对象的类,它的主要作用是创建具体的产品类实例.我们以一个生产鼠标为例来分析简单工厂的作用,鼠标有两种:戴尔鼠标和惠普 ...