php+ajax發(fā)起流程和審核流程(以請(qǐng)假為例)
上一篇隨筆中已經(jīng)提到如何新建流程,那么現(xiàn)在我們就來看一下如何發(fā)起一個(gè)流程和審核流程~~~
先說一下思路:
(1)登錄用session獲取到用戶的id
(2) 用戶發(fā)起一個(gè)流程
注意:需要寫申請(qǐng)事由
(3)處于節(jié)點(diǎn)的審核人去依次審核
注意:每審核通過一個(gè),對(duì)應(yīng)towhere字段要加1; 審核到最后時(shí),對(duì)應(yīng)的isok字段要變?yōu)?(此處1表示結(jié)束,0表示未結(jié)束)
共用到三張表:

第一步:先做一個(gè)簡(jiǎn)單的登錄頁面,用session獲取用戶名:
denglu.php頁面
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <form method="post" action="denglu-cl.php"> 用戶名:<input type="text" name="uid" /><br /> 密碼:<input type="password" name="pwd" /><br /> <input type="submit" value="登錄" /> </form> </body> </html>
denglu-cl.php頁面
<?php
session_start();
require "../DB.class.php";
$db = new DB();
$uid = $_POST["uid"];
$pwd = $_POST["pwd"];
$sql = "select pwd from users where uid='{$uid}'";
$mm = $db->strquery($sql);
if($pwd==$mm && !empty($pwd))
{
$_SESSION["uid"]=$uid;
header("location:liucheng.php");
}
else
{
echo "密碼或登錄名輸入錯(cuò)誤";
}
?>
效果圖:

第二步:做個(gè)簡(jiǎn)單的注頁面:liucheng.php
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
#body{
height: 200px;
width: 300px;
background-color: gainsboro;
margin: 200px auto;
text-align: center;
vertical-align: middle;
line-height: 30px;
}
</style>
</head>
<body>
<div id="body">
<h2>主頁面</h2>
<div>
<a href="faqi.php" rel="external nofollow" >發(fā)起流程</a><br />
<a href='shenhe.php'>審核流程</a>
</div>
</div>
</body>
</html>
效果圖:

第三步:發(fā)起流程頁面faqi.php
(1)先將所有流程用下拉列表顯示
(2)發(fā)起流程事由需要由登錄用戶填寫
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
#body{
height: 250px;
width: 300px;
background-color: gainsboro;
margin: 200px auto;
text-align: left;
vertical-align: middle;
line-height: 30px;
padding-left: 30px;
}
</style>
</head>
<body>
<div id="body">
<form method="post" action="faqi-cl.php">
<h2>發(fā)起流程頁面</h2>
<select id="lc">
<?php
require "../DB.class.php";
$db = new DB();
$sql = "select * from liucheng";
$arr = $db->query($sql);
foreach($arr as $v)
{
echo "<option value='{$v[0]}'>{$v[1]}</option>";
}
?>
</select><br />
發(fā)起流程事由:
<textarea class="nr"> </textarea><br />
<input type="button" value="確定發(fā)起" />
</form>
</div>
</body>
</html>

第四步:寫發(fā)起流程的處理頁面fq-cl.php
<?php
session_start();
require "../DB.class.php";
$db = new DB();
$code = $_POST["lc"];
$nr =$_POST["nr"];
$uid = $_SESSION["uid"];
$time = date("Y-m-d H:i:s",time());
$sql = "insert into liuchengpath values ('','{$code}','{$uid}','{$nr}',0,'{$time}',0)";
$db->query($sql,0);
header("location:liucheng.php");
?>
點(diǎn)擊“確認(rèn)發(fā)起”,數(shù)據(jù)庫中就會(huì)添加此條數(shù)據(jù)

第五步:流程審核頁面shenhe.php
用到知識(shí)點(diǎn):子查詢:無關(guān)子查詢(子查詢和父查詢可以獨(dú)立執(zhí)行); 相關(guān)子查詢(子查詢里的條件使用到了父查詢的某個(gè)東西 )
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
#body{
height: 450px;
width: 800px;
background-color: gainsboro;
margin: 200px auto;
text-align: left;
vertical-align: middle;
line-height: 30px;
padding-left: 30px;
}
</style>
</head>
<body>
<div id="body">
<h2>流程審核頁面</h2>
<?php
session_start();
$uid = $_SESSION["uid"];
require "../DB.class.php";
$db = new DB();
//先取該用戶參與的所有流程
//并且取流程步驟到達(dá)該用戶或已經(jīng)被改用戶審核通過的記錄
$sql="select * from liuchengpath a where code in(select code from liuchengjiedian where uids='{$uid}') and towhere >=(select orders from liuchengjiedian b where b.code = a.code and b.uids = '{$uid}')";
$arr = $db->query($sql);
//var_dump($arr);
echo "<table border='1' width='100%' cellpadding='0' cellspacing='0'>
<tr>
<td>流程代號(hào)</td>
<td>發(fā)起者</td>
<td>發(fā)起內(nèi)容</td>
<td>發(fā)起時(shí)間</td>
<td>是否結(jié)束</td>
<td>操作</td>
</tr>";
foreach($arr as $v){
//操作最后一列
//設(shè)置默認(rèn)項(xiàng)
$zt = "<a href='tongguo-cl.php?code={$v[0]}'>審核未通過</a>";
$sql = "select orders from liuchengjiedian where code ='{$v[1]}' and uids ='{$uid}'";
$wz = $db->strquery($sql);
if($v[6]>$wz)
{
$zt = "<span style='color:green'>審核已通過</span>";
}
echo "<tr>
<td>{$v[1]}</td>
<td>{$v[2]}</td>
<td>{$v[3]}</td>
<td>{$v[4]}</td>
<td>{$v[5]}</td>
<td>{$zt}</td>
</tr>";
}
echo "</table>";
?>
</div>
</body>
</html>
第六步:寫tongguo-cl.php頁面(重要)
<?php
$ids = $_GET["code"];
require "../DB.class.php";
$db = new DB();
//點(diǎn)擊審核后,towhere列加1,目的是使流程向下走
$sql = "update liuchengpath set towhere = towhere+1 where ids ='{$ids}' ";
$db->query($sql,0);
//當(dāng)流程走到最后一個(gè)審核的人時(shí),流程要結(jié)束
//獲取該流程最大的orders
$sql =" select max(orders) from liuchengjiedian where code = (select code from liuchengpath where ids ='{$ids}')";
$maxorders = $db->strquery($sql);
//獲取該用戶處于哪個(gè)位置,也就是towhere等于多少
$sql ="select towhere from liuchengpath where ids ='{$ids}'";
$towhere = $db->strquery($sql);
//判斷是否已到達(dá)最后一個(gè)審核的人
if($towhere>$maxorders)
{
$sql = "update liuchengpath set isok=1 where ids='{$ids}'";
// var_dump($sql);
$db->query($sql,0);
}
header("location:shenhe.php");
?>
當(dāng)寫好這一步時(shí),點(diǎn)擊“審核未通過”則會(huì)變成“審核已通過”;

我們從頭來驗(yàn)證一下效果:
首先:發(fā)起一個(gè)新的請(qǐng)假流程:

其次:zhangsan是第一個(gè)要審核人


點(diǎn)擊“審核未通過后“,

最后:zhaoliu是最后一個(gè)審核人


點(diǎn)擊“審核未通過”后,是否結(jié)束變?yōu)?nbsp; 1 ;操作變?yōu)榫G色的 “審核已通過”~~~

以上所述是小編給大家介紹的php+ajax發(fā)起流程和審核流程(以請(qǐng)假為例),希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
- PHP設(shè)計(jì)模式之責(zé)任鏈模式的深入解析
- 簡(jiǎn)單介紹PHP的責(zé)任鏈編程模式
- php注冊(cè)審核重點(diǎn)解析(數(shù)據(jù)訪問)
- 如何用PHP做到頁面注冊(cè)審核
- PHP代碼審核的詳細(xì)介紹
- PHP設(shè)計(jì)模式之狀態(tài)模式定義與用法詳解
- 學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)狀態(tài)模式
- 詳解PHP中的狀態(tài)模式編程
- php設(shè)計(jì)模式 State (狀態(tài)模式)
- PHP實(shí)現(xiàn)基于狀態(tài)的責(zé)任鏈審批模式詳解
相關(guān)文章
TP5框架請(qǐng)求響應(yīng)參數(shù)實(shí)例分析
這篇文章主要介紹了TP5框架請(qǐng)求響應(yīng)參數(shù),結(jié)合實(shí)例形式分析了thinkPHP5請(qǐng)求參數(shù)及相應(yīng)參數(shù)的獲取方法,需要的朋友可以參考下2019-10-10
laravel admin實(shí)現(xiàn)分類樹/模型樹的示例代碼
這篇文章主要介紹了laravel admin實(shí)現(xiàn)分類樹/模型樹,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
php+memcache實(shí)現(xiàn)的網(wǎng)站在線人數(shù)統(tǒng)計(jì)代碼
這篇文章主要介紹了php+memcache實(shí)現(xiàn)的網(wǎng)站在線人數(shù)統(tǒng)計(jì)代碼,代碼例子簡(jiǎn)潔實(shí)用,需要的朋友可以參考下2014-07-07
layui框架實(shí)現(xiàn)文件上傳及TP3.2.3(thinkPHP)對(duì)上傳文件進(jìn)行后臺(tái)處理操作示例
PHP數(shù)據(jù)庫萬能引擎類adodb配置使用以及實(shí)例集錦

