AI编程助手
AI免费问答

php+ajax实现发起流程和审核流程的方法

墨辰丷   2018-05-21 15:21   3295浏览 原创

这篇文章主要介绍了php+ajax发起流程和审核流程(以请假为例) ,需要的朋友可以参考下

先说一下思路:

(1)登录用session获取到用户的id

 (2) 用户发起一个流程

         注意:需要写申请事由

(3)处于节点的审核人去依次审核

          注意:每审核通过一个,对应towhere字段要加1; 审核到最后时,对应的isok字段要变为1(此处1表示结束,0表示未结束)

共用到三张表:

第一步:先做一个简单的登录页面,用session获取用户名:

denglu.php页面

nbsp;html>

 
 <meta>
 <title></title>
 
 
 
  用户名:
  密码:
    
 

  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=&#39;{$uid}&#39;";
$mm = $db->strquery($sql);
if($pwd==$mm && !empty($pwd))
{
 $_SESSION["uid"]=$uid;
 header("location:liucheng.php");
}
else
{
 echo "密码或登录名输入错误";
}
?>

  效果图:

第二步:做个简单的注页面:liucheng.php

nbsp;html>

 
 <meta>
 <title></title>
 <style>
  #body{
  height: 200px;
  width: 300px;
  background-color: gainsboro;
  margin: 200px auto;
  text-align: center;
  vertical-align: middle;
  line-height: 30px;
  }
 </style>
 
 
 <p>
 </p><h2>主页面</h2>
 <p>
  <a>发起流程</a><br>
  <a>审核流程</a>
 </p>
 
 

 效果图:

第三步:发起流程页面faqi.php

(1)先将所有流程用下拉列表显示

(2)发起流程事由需要由登录用户填写

nbsp;html>

 
 <meta>
 <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>
 
 
 <p>
  </p>
  

发起流程页面

  
  发起流程事由:   
      
   

第四步:写发起流程的处理页面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 (&#39;&#39;,&#39;{$code}&#39;,&#39;{$uid}&#39;,&#39;{$nr}&#39;,0,&#39;{$time}&#39;,0)";
$db->query($sql,0);
header("location:liucheng.php");
?>

  点击“确认发起”,数据库中就会添加此条数据

第五步:流程审核页面shenhe.php

用到知识点:子查询:无关子查询(子查询和父查询可以独立执行); 相关子查询(子查询里的条件使用到了父查询的某个东西   )

nbsp;html>

 
 <meta>
 <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>
 
 
 <p>
  </p><h2>流程审核页面</h2>
  <?php   session_start();
  $uid = $_SESSION["uid"];
  require "../DB.class.php";
  $db = new DB();
  //先取该用户参与的所有流程
  //并且取流程步骤到达该用户或已经被改用户审核通过的记录
  $sql="select * from liuchengpath a where code in(select code from liuchengjiedian where uids=&#39;{$uid}&#39;) and towhere >=(select orders from liuchengjiedian b where b.code = a.code and b.uids = '{$uid}')";
  $arr = $db->query($sql);
  //var_dump($arr);
  echo "
                                       ";   foreach($arr as $v){    //操作最后一列    //设置默认项    $zt = "审核未通过";    $sql = "select orders from liuchengjiedian where code ='{$v[1]}' and uids ='{$uid}'";    $wz = $db->strquery($sql);    if($v[6]>$wz)    {    $zt = "审核已通过";    }    echo "                                  ";      }   echo "
流程代号发起者发起内容发起时间是否结束操作
{$v[1]}{$v[2]}{$v[3]}{$v[4]}{$v[5]}{$zt}
";     ?>    

  第六步:写tongguo-cl.php页面(重要)

<?php $ids = $_GET["code"];
require "../DB.class.php";
$db = new DB();
//点击审核后,towhere列加1,目的是使流程向下走
$sql = "update liuchengpath set towhere = towhere+1 where ids =&#39;{$ids}&#39; ";
$db->query($sql,0);
//当流程走到最后一个审核的人时,流程要结束
//获取该流程最大的orders
$sql =" select max(orders) from liuchengjiedian where code = (select code from liuchengpath where ids ='{$ids}')";
$maxorders = $db->strquery($sql);
//获取该用户处于哪个位置,也就是towhere等于多少
$sql ="select towhere from liuchengpath where ids ='{$ids}'";
$towhere = $db->strquery($sql);
//判断是否已到达最后一个审核的人
if($towhere>$maxorders)
{
 $sql = "update liuchengpath set isok=1 where ids='{$ids}'";
// var_dump($sql);
 $db->query($sql,0);
}
header("location:shenhe.php");
?>

  当写好这一步时,点击“审核未通过”则会变成“审核已通过”;

我们从头来验证一下效果:

首先:发起一个新的请假流程:

其次:zhangsan是第一个要审核人

点击“审核未通过后“,

最后:zhaoliu是最后一个审核人

点击“审核未通过”后,是否结束变为  1 ;操作变为绿色的  “审核已通过”~~~

相关推荐:

php流程控制之continue语句

php流程控制之break语句

php流程控制之什么是foreach

php免费学习视频:立即学习
踏上前端学习之旅,开启通往精通之路!从前端基础到项目实战,循序渐进,一步一个脚印,迈向巅峰!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。