Maison  >  Article  >  développement back-end  >  Étude de cas d'implémentation de la fonction de gestion de processus PHP

Étude de cas d'implémentation de la fonction de gestion de processus PHP

黄舟
黄舟original
2017-09-25 09:37:251895parcourir

Logique de base : la gestion des processus joue un rôle très important dans divers systèmes. Vous pouvez mettre le processus défini dans le système et spécifier plusieurs nœuds tant que tous les nœuds réussissent, il peut réussir.

Créez quatre tables de base de données :

1. Créons d'abord une nouvelle page de processus flow.php, et créons d'abord les nœuds


<!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>
        <p><select id="users" name="users">
            <? "./DBDA.class.php" =  = "select * from users" = ->query(,0(   "<option value=&#39;{[0]}&#39;>{[2]}</option>"?>
            </select>
            <input type="button" value="添加" id="add" />
        </p>        
        <br />
        <p>
            <?((["jd" "还未添加节点人员!" = ["jd"];
                (  =>){
                     = "select name from users where uid=&#39;{}&#39;" = ->StrQuery(,0);
                     "<p>{}--{}--<input type=&#39;button&#39; value=&#39;删除&#39; class=&#39;del&#39; code=&#39;{}&#39; /></p>"?>
        </p>
        <br />
        <p><input type="text" id="name" />
        </p>
        <br />
        <input type="button" value="新建" id="addbtn" />
    </body>
    <script>      
"#add").click( uid = $("#users")..:"flowchuli.php",:"POST",:{uid:uid,type:0},:"TEXT",:.location.href = "flow.php"".del").click( k = $(this).attr("code");
            $.:"flowchuli.php",:"POST",:{k:k,type:1},:"TEXT",:.location.href = "flow.php"
        $("#addbtn").click( name = $("#name")..:"flowchuli.php",:"POST",:{name:name,type:2},:"TEXT",:"添加成功!"</script>
</html>

2. Créons la page de traitement flowchuli pour le nouveau processus. page .php


<?phpsession_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(&#39;{$code}&#39;,&#39;{$name}&#39;)";//流程表
        $db->query($sql);        //流程节点表
        $arr = $_SESSION["jd"];        foreach($arr as $k=>$v){            $sql = "insert into flowpath values(0,&#39;{$code}&#39;,&#39;{$v}&#39;,{$k})";            $db->query($sql);
        }        
        break;
}

L'effet est le suivant :

Cliquez pour sélectionner le personnel du nœud à appeler la liste de tout le personnel de la base de données, mettez maintenant Li Si, Ma Qi et Zhang San dans le processus et faites un processus de demande de congé :

Remarque : le code doit utiliser varchar, pas l'heure, car l'horodatage est utilisé ci-dessus

3.Maintenant, nous créez une page utilisateur de connexion flowlogin.php, soumettez toutes les étapes du processus de demande de congé :


<!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>
        .-left:-top:.-left:-top: -.name,.-width:.-top:</style>
    <body>        
<form ="form-horizontal" role="form">
    <h3 ="title">用户登录</h3>
    <p ="quanju">
            <p ="form-group yangshi1">
                <label ="firstname" ="col-sm-2 control-label">用户名:</label>
                <p ="col-sm-10">
                    <input type="text" ="form-control name" id="uid" placeholder="请输入用户名">
                </p>
            </p>
            <p ="form-group yangshi2">
                <label ="lastname" ="col-sm-2 control-label">密码:</label>
                <p ="col-sm-10">
                    <input type="text" ="form-control pwd" id="pwd" placeholder="请输入密码">
                </p>
            </p>
            <p ="form-group">
                <p ="col-sm-offset-2 col-sm-10">
                    <p ="checkbox">
                        <label>
                        <input type="checkbox"></label>
                        <label>
                        <input type="checkbox"></label>
                    </p>
                </p>
            </p>
            <p ="form-group">
                <p ="col-sm-offset-2 col-sm-10">
                    <button type="button" id="login" ="btn btn-warning" value="登录" ></button>
                    
                </p>
            </p>
        </p>    
    </form>        
    </body>
    <script>
"#login").click( uid = $("#uid"). pwd = $("#pwd")..:"post",:"flowloginchuli.php",:{uid:uid,pwd:pwd},:"TEXT",:(data.()=="OK".location.href="flowmain.php""用户名或密码有误!"</script>
</html>

4. La page principale qui saute après la connexion, 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. Lancer la page de traitement du processus 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=&#39;{$v[0]}&#39;>{$v[1]}</option>";
                }                ?>
            </select>
            <br />
            <br />
            请输入内容:            <textarea name="content"></textarea>
            <br />
            <br />
            <input type="submit" value="确定" />
        </form>        
    </body>
</html>

6. Effectuer la page de traitement du processus de lancement flowfq.php


<?phpsession_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,&#39;{$code}&#39;,&#39;{$uid}&#39;,&#39;{$content}&#39;,0,&#39;{$time}&#39;,0)";$db->query($sql);header("location:flowmain.php");

7. Consultez la page flowh.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>
    <p><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=&#39;{$uid}&#39;)";    
                $arr = $db->query($sql,0);    
                foreach($arr as $v){                    //$v[6];//流程走到的位置towhere
                    //$v[1];//利用代号和session中存的name查询order
                    $sql = "select order from flowpath where code=&#39;{$v[1]}&#39; and uid=&#39;{$uid}&#39;";                    $order = $db->StrQuery($sql,0);//该人员在流程中的次序
                    $str = "";                    if($v[6]==$order){                            //传主键值
                        $str = "<a href=&#39;flowtgchuli.php?ids={$v[0]}&#39;>通过</a>";
                    }else{                        $str = "<span style=&#39;color:green&#39;>已通过</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>
    </p>    
    </body>
</html>

8. 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=&#39;{$ids}&#39;";
$db->query($sql);//判断;流程是否结束(使用相关子查询)
$swc = "update userflow a set isok=1 where ids=&#39;{$ids}&#39; towhere>=(select count(*) from flowpath b where b.code=a.code)";header("location:flowsh.php");

L'effet du processus est le suivant :

Page de Li Si :

Après en cliquant sur :

Base de données : Le processus se termine lorsque towhere devient 1

Puis le cheval sept :

Ensuite, il y a Zhang San :

Base de données : Terminer le processus une fois qu'isok devient 1

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn