php流程管理

时间:2021-06-12 00:24:47

流程控制即某个人发起一个流程,通过一层一层审核,通过后,完成整个流程,若有一层审核未通过,中断整个流程。即结束!

比如请假流程:

某一员工发起一个请假流程,那么这个流程的节点人员即他的上级,上上级,上上上级......若上级领导未通过,即结束整个流程

1.数据库中的内容:

php流程管理php流程管理php流程管理php流程管理

用户员工表,流程表,用户编写的流程表,还有审核人员

2.新建流程页面,即发起流程页面:

<div>
  请选择节点人员:

    <?php
    session_start();   //开启session
    include("DBDA.class.php");   //调用封装好的数据库
    $db = new DBDA();  //造新对象

    $suser = "select * from users";  //查询用户表中的所有值
    $auser = $db->Query($suser);  //执行查询语句
    foreach($auser as $v)
    {
        echo "<input class='ck' type='radio' value='{$v[0]}' name='ck' />{$v[2]} ";  //输出单选按钮,数组中的索引2,也就是用户名,但是它的值是代号
    }
    ?>
</div>

在把添加节点的按钮加上:

<input type="button" value="添加节点" id="jd" /> 

图:

php流程管理

按钮点击事件:

  $("#jd").click(function(){
        var uid = $("#user").val();   //点击添加节点,是要把select里面的value值添加过来,那么我们就要先取出它的value值
        $.ajax({
            url:"chuli.php",
            data:{uid:uid},
            type:"POST",
            dataType:"TEXT",
            success: function(data){
                window.location.href="main.php"; //刷新页面即可
            }
        });
    })

来处理:

 <?php
  session_start(); //首先要开启session

  $uid = $_POST["uid"];
  if(empty($_SESSION["user"]))//如果节点里面没有内容 需要先建一个数组,然后把uid放到里面 存一下
  {
      $arr = array($uid);
      $_SESSION["user"] = $arr;
  }
 else            //如果里面已经有内容了,那么就把数组里面的内容存一下
 {
     $arr = $_SESSION["user"];
     array_push($arr,$uid);
     $_SESSION["user"] = $arr;
 }

图:

php流程管理

删除按钮的事件:

     $(".del").click(function(){
          var key=$(this).attr("key"); //删除里面取key值写起来是非常方便的
          $.ajax({
              url:"shanchu.php",
              data:{key:key},
              type:"POST",
              dataType:"TEXT",
              success:function(aa)
             {
                 window.location.href="main.php";
            }
         })
14     })

来处理:

<?php
session_start();
$arr=$_SESSION["user"];  //把之前的节点内容存一下 给$arr
$key=$_POST["key"];  //取出索引值

unset($arr[$key]);  //把选中的删除

$arr = array_values($arr); //把现有的节点的顺序重新排

$_SESSION["user"]=$arr;

输入流程名称:

<div>请输入流程名称:<input type="text" id="name" /></div><di>input type="button" value="保存" id="save" /></div> 

保存按钮的事件:

 $("#btn").click(function(){
var nr=$("#nr").val();
$.ajax({
url:"baocun.php",
data:{nr:nr},
type:"POST",
dataType:"TEXT",
success:function(bc){
alert("保存成功");
} })
})

保存流程处理:

<?php
session_start();
include("DADB.class.php");
$db=new DADB();
$nr=$_POST["nr"];
$code=time();
$sql="insert into liucheng VALUES ('{$code}','{$nr}')"; //在liucheng表中添加内容
$db->Query($sql,0);

//在liucheng表中添加完之后还要保存节点  节点是在flowpath表中的

$arr = $_SESSION["user"];
foreach($arr as $k=>$v)
{
    $sqn="insert into flowpath VALUES ('','{$code}','{$v}','{$k}')";
    $db->Query($sqn,0);
}

图:

php流程管理

 保存成功!

3.登入写过很多,不再一点点敲了:

4.节点人员界面:

<h1>审核页面</h1>
<table width="100%" border="1" cellpadding="0" cellspacing="0">
    <tr>
        <td>流程代号</td>
        <td>发起者</td>
        <td>发起内容</td>
        <td>是否结束</td>
        <td>发起时间</td>
        <td>操作</td>
    </tr>
    <?php
    session_start();

    $uid=$_SESSION["uid"];
    echo $uid;
    include("DADB.class.php");
    $db=new DADB();
    //查找登录者参与的所有流程
    $sql = "select * from userflow where code in(select code from flowpath where uids='{$uid}')";
    $arr = $db->Query($sql);
    //显示在页面
    foreach($arr as $v)
    {
         $dh=$v[1];//查出代号
        $where=$v[6]; //查出流程到哪里了

        $sqn="select orders from flowpath where code='{$dh}' and uids='{$uid}'";
        $orders=$db->StrQuery($sqn);//查出在流程中的次序

        if($where>=$orders)
        {
            $caozuo = "";
            if($where==$orders)
            {
                $caozuo="<a href='tongguo.php?code={$v[0]}'>通过</a>";
            }
            else
            {
                $caozuo="<span style='background-color:green;color:white'>已通过</span>";
            }
            echo "<tr>
        <td>{$v[1]}</td>
        <td>{$v[2]}</td>
        <td>{$v[3]}</td>
        <td>{$v[4]}</td>
        <td>{$v[5]}</td>
        <td>{$caozuo}</td>
    </tr>";
        }

    }
    ?>

</table>

看一下最后点击后的处理页面:

<?php
session_start();
include("../fengzhuang/DBDA.class.php");
$db = new DBDA();

//流程往下走
$code = $_GET["code"];
$sql = "update userflow set towhere=towhere+1 where ids='{$code}'";
$db->Query($sql,0);

//判断流程是否结束
$sql = "select * from userflow where ids='{$code}'";
$arr = $db->Query($sql);

$lcdh = $arr[0][1]; //流程代号
$tw = $arr[0][6]; //流程走到哪

$sql = "select count(*) from flowpath where code='{$lcdh}'";
$count = $db->StrQuery($sql); //该流程节点人数
if($tw>=$count)
{
    $sql = "update userflow set isok=1 where ids='{$code}'";
    $db->Query($sql,0);
}

header("location:shenhe.php");

这个主要是逻辑麻烦,没错!