>백엔드 개발 >PHP 튜토리얼 >PHP 프로세스 관리 기능 구현 사례 연구

PHP 프로세스 관리 기능 구현 사례 연구

黄舟
黄舟원래의
2017-09-25 09:37:251917검색

핵심 로직: 프로세스 관리는 다양한 시스템에서 매우 중요한 역할을 합니다. 설정된 프로세스를 시스템에 넣고 여러 노드를 지정하면 통과할 수 있습니다.

4개의 데이터베이스 테이블 생성:

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>
        <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. 프로세스 처리 페이지 flowchuli.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;
}

효과는 그림과 같습니다.

노드 직원을 선택하여 데이터베이스의 모든 직원 목록을 호출합니다. 이제 Li Si, Ma를 입력합니다. Qi와 Zhang San을 프로세스에 포함시킵니다.

코드에서는 타임스탬프가 사용되므로 시간이 아닌 varchar를 사용해야 합니다

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>
        .-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 로그인 후 점프하는 메인 페이지 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 프로세스 페이지를 시작합니다.


<!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. 프로세스 처리 페이지 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을 만듭니다. 리뷰 페이지 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>
    <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. Process 프로세스 효과는 그림에 표시된 것과 같습니다. Qi:


그런 다음 Zhang San:

데이터베이스: isok이 1

이 된 후 프로세스를 종료합니다.

위 내용은 PHP 프로세스 관리 기능 구현 사례 연구의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.