• PHP流程管理,堪比小小程序


    这个流程管理是从用户登录界面开始,然后提交申请,页面逐级审核通过。这个做起来其实挺简单,只是在某些逻辑方面需要

    好好考虑一下。

    登录页面就不再多说了,如果要存session的话,我们可以建一个假的登录页面,只把uid存进session里面。

    weilogin:假的登录页面

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无标题文档</title>
    </head>
    
    <body>
    <?php
    session_start();
    $_SESSION["uid"] = "zhangsan";
    ?>
    </body>
    </html>
    

    新建流程页面,里面有选择节点人员,发起流程,等操作

    xinjian.php

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无标题文档</title>
    <script src="../jquery/jquery-1.11.2.min.js"></script>
    </head>
    
    <body>
    <h1>新建流程</h1>
    
    <div>
    请选择节点人员:
    <select id="user">
    	<?php
    	session_start();
    	include("../fengzhuang/DBDA.class.php");
    	$db = new DBDA();
    	
    	$sql = "select * from users";
    	$arr = $db->Query($sql);
    	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["user"]))
    	{
    		$attr = $_SESSION["user"];
    		foreach($attr as $k=>$v)
    		{
    			$sname = "select name from users where uid='{$v}'";
    			$name = $db->StrQuery($sname);
    			echo "<div>{$k}--{$name}--<input type='button' value='删除' key='{$k}' class='del' /></div>";
    		}
    	}
    	?>
    </div>
    <br />
    <div>请输入流程名称:<input type="text" id="name" /></div>
    <br />
    <input type="button" value="保存" id="btn" />
    
    
    </body>
    <script type="text/javascript">
    //添加节点按钮加点击
    $("#add").click(function(){
    		var uid = $("#user").val();
    		$.ajax({
    			url:"chuli.php",
    			data:{uid:uid,type:0},
    			type:"POST",
    			dataType:"TEXT",
    			success: function(data){
    					window.location.href="xinjian.php";
    				}
    			});
    	})
    	
    //给删除按钮加点击
    $(".del").click(function(){
    		var key = $(this).attr("key");
    		$.ajax({
    			url:"chuli.php",
    			data:{key:key,type:1},
    			type:"POST",
    			dataType:"TEXT",
    			success:function(data){
    				window.location.href="xinjian.php";
    				}
    			});
    	})
    //给保存按钮加点击
    $("#btn").click(function(){
    		var name = $("#name").val();
    		$.ajax({
    			url:"chuli.php",
    			data:{name:name,type:2},
    			type:"POST",
    			dataType:"TEXT",
    			success:function(data){
    					alert("保存成功!");
    				}
    			});
    	})
    </script>
    </html>
    

    他们的每种方法都被引用在了一个页面,用switch方法,

    chuli.php

    <?php
    session_start();
    include("../fengzhuang/DBDA.class.php");
    $db = new DBDA();
    
    $type = $_POST["type"];
    
    switch($type)
    {
    	case 0:
    		$uid = $_POST["uid"];
    		if(empty($_SESSION["user"]))
    		{
    			$arr = array($uid);
    			$_SESSION["user"] = $arr;
    		}
    		else
    		{
    			$arr = $_SESSION["user"];
    			array_push($arr,$uid);
    			$_SESSION["user"] = $arr;
    		}
    		break;
    		
    	case 1:
    		$key = $_POST["key"];
    		$arr = $_SESSION["user"];
    		unset($arr[$key]); //删除
    		$arr = array_values($arr); //重新索引
    		$_SESSION["user"] = $arr;
    		break;
    		
    	case 2:
    		$name = $_POST["name"];
    		$code = time();
    		//添加流程
    		$sql = "insert into liucheng values('{$code}','{$name}')";
    		$db->Query($sql,0);
    		//添加流程节点
    		$arr = $_SESSION["user"];
    		foreach($arr as $k=>$v)//获取索引
    		{
    			$sql = "insert into flowpath values('','{$code}','{$v}','{$k}')";
    			$db->Query($sql,0);
    		}
    		break;
    		
    	case 3: //用户发起流程
    		$code = $_POST["code"];
    		$nr = $_POST["content"];
    		$uid = $_SESSION["uid"];
    		$time = date("Y-m-d H:i:s");
    		$sql = "insert into userflow values('','{$code}','{$uid}','{$nr}',0,'{$time}',0)";
    		$db->Query($sql,0);
    		break;
    		
    }
    

    然后是发起流程环节,

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无标题文档</title><br />
    <script src="../jquery/jquery-1.11.2.min.js"></script>
    
    </head>
    
    <body>
    
    <h1>发起流程</h1>
    
    <div>
    请选择发起的流程:
    	<select id="liucheng">
        	<?php
    		session_start();
    		include("../fengzhuang/DBDA.class.php");
    		$db = new DBDA();
    		$sql = "select * from liucheng";
    		$arr = $db->Query($sql);
    		foreach($arr as $v)
    		{
    			echo "<option value='{$v[0]}'>{$v[1]}</option>";
    		}
    		?>
        </select>
    </div>
    <br />
    <div>
    请输入内容:
    	<textarea id="nr"></textarea>
    </div>
    <br />
    <input type="button" value="发起" id="btn" />
    
    
    </body>
    <script type="text/javascript">
    $("#btn").click(function(){
    		var code = $("#liucheng").val();
    		var content = $("#nr").val();
    		
    		$.ajax({
    			url:"chuli.php",
    			data:{code:code,content:content,type:3},
    			type:"POST",
    			dataType:"TEXT",
    			success: function(data){
    				alert("发起成功!");
    				}			
    			});
    	})
    </script>
    </html>
    

     

    紧接着是审核页面,这个需要判断流程走到哪个登录者,流程代号,流程走到哪,和该人员在流程中的次序。shenhe.php

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无标题文档</title>
    </head>
    
    <body>
    <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();
    	include("../fengzhuang/DBDA.class.php");
    	$db = new DBDA();
    	$uid = $_SESSION["uid"];
    	echo $uid;
    	//查找登录者参与的所有流程
    	$sql = "select * from userflow where code in(select code from flowpath where uids='{$uid}')";
    	$arr = $db->Query($sql);
    	
    	//显示
    	foreach($arr as $v)
    	{
    		//判断该流程走到登录者
    		$lcdh = $v[1]; //流程代号
    		$towhere = $v[6];//流程走到哪
    		$sql = "select orders from flowpath where code='{$lcdh}' and uids='{$uid}'";
    		$order = $db->StrQuery($sql);//该人员在流程中的次序
    		
    		if($towhere>=$order)
    		{
    			$caozuo = "";
    			if($towhere==$order)
    			{
    				$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>
    </body>
    </html>
    

    最后我们要通过了处理了....tongguo.php

    <?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");

  • 相关阅读:
    malloc和new的区别
    Http协议解析
    Linux基础命令-history
    Linux基础命令-last
    Linux基础命令-who
    Linux基础命令-free
    Linux基础命令-uptime
    Linux基础命令-uname
    Linux基础命令-ifconfig
    Linux基础命令-killall
  • 原文地址:https://www.cnblogs.com/li1056822533/p/6604795.html
Copyright © 2020-2023  润新知