ThinkPHP6中怎样举行审核流程治理?
随着互联网的生长,越来越多的企业最先使用网络举行营业处理,这就要求企业必需有一套完善的审核流程治理系统来确保营业的清静和规范。在php开发中,thinkphp6框架提供了便捷的审核流程治理功效,本文将先容怎样在thinkphp6中实现审核流程治理。
一、ThinkPHP6审核流程治理基本思绪
ThinkPHP6的审核流程治理基本思绪是通过数据库纪录来实现,一样平常需要建设两个数据表:
流程表:纪录审核流程的基本信息,如流程名称、建设者、建设时间等;
办法表:纪录审核流程中详细的审核办法,包括每个审核办法的名称、状态、处理人、处理时间等。
审核流程治理的流程可以简朴形貌如下:
建设审核流程:治理员在后台建设审核流程,并设置每个审核办法的名称、处理人等信息;
提交审核:用户提交审核申请,系统凭证审核流程最先审核;
审核流程中的审核办法:凭证流程表和办法表中纪录的信息,自动分派审核职员举行审核;
审核效果:审核通过或欠亨过,最终得出审核效果。
二、建设流程表和办法表
连忙学习“PHP免费学习条记(深入)”;
首先,我们需要在数据库中建设流程表和办法表。
流程表:
CREATE TABLE `tp_flow` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID', `name` varchar(50) DEFAULT NULL COMMENT '流程名称', `create_user_id` int(11) DEFAULT NULL COMMENT '建设人ID', `create_time` datetime DEFAULT NULL COMMENT '建设时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='审核流程表';
登录后复制
办法表:
CREATE TABLE `tp_step` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID', `flow_id` int(11) DEFAULT NULL COMMENT '流程ID', `name` varchar(50) DEFAULT NULL COMMENT '办法名称', `status` tinyint(1) DEFAULT '0' COMMENT '状态:0-未处理,1-已处理', `handler_id` int(11) DEFAULT NULL COMMENT '处理人ID', `handle_time` datetime DEFAULT NULL COMMENT '处理时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='审核办法表';
登录后复制
三、建设模子类
接下来,我们需要建设模子类,界说流程表和办法表的关系,并实现州操作要领。
建设流程模子类
首先,我们建设流程模子类FlowModel,界说与办法模子类StepModel的一对多关系,并提供流程治理相关要领。
// ppmodelFlowModel.php namespace appmodel; use thinkModel; class FlowModel extends Model { protected $table = 'tp_flow'; // 界说与StepModel的一对多关系 public function steps() { return $this->hasMany('StepModel', 'flow_id', 'id'); } // 建设审核流程 public function addFlow($data) { return $this->save($data); } // 编辑审核流程 public function editFlow($id, $data) { return $this->where('id', $id)->update($data); } // 删除审核流程 public function delFlow($id) { return $this->where('id', $id)->delete(); } // 凭证ID获取审核流程详情 public function getFlowById($id) { return $this->with('steps')->find($id); } // 获取审核流程列表 public function getFlowList() { return $this->with('steps')->select(); } }
登录后复制
2.建设办法模子类
然后,我们建设办法模子类StepModel,界说与流程模子类FlowModel的属于关系,并提供审核办法相关的要领。
// ppmodelStepModel.php namespace appmodel; use thinkModel; class StepModel extends Model { protected $table = 'tp_step'; // 界说与FlowModel的属于关系 public function flow() { return $this->belongsTo('FlowModel', 'flow_id'); } // 添加审核办法 public function addStep($data) { return $this->save($data); } // 编辑审核办法 public function editStep($id, $data) { return $this->where('id', $id)->update($data); } // 删除审核办法 public function delStep($id) { return $this->where('id', $id)->delete(); } // 凭证ID获取审核办法详情 public function getStepById($id) { return $this->find($id); } // 获取审核办法列表 public function getStepListByFlowId($flow_id) { return $this->where('flow_id', $flow_id)->select(); } // 更新审核办法状态 public function updateStepStatus($id, $status, $handler_id, $handle_time) { $data = [ 'status' => $status, 'handler_id' => $handler_id, 'handle_time' => $handle_time, ]; return $this->where('id', $id)->update($data); } }
登录后复制
三、审核流程的实现
在审核流程的实现中,我们需要在控制器或效劳层中挪用流程和办法模子类的要领,来完成审核流程的各个办法。
建设审核流程
治理员在后台建设审核流程时,需要先建设流程,然后添加办法。
// ppcontrollerFlowController.php namespace appcontroller; use appBaseController; use appmodelFlowModel; use appmodelStepModel; use thinkRequest; class FlowController extends BaseController { protected $flowModel; protected $stepModel; public function __construct(FlowModel $flowModel, StepModel $stepModel) { $this->flowModel = $flowModel; $this->stepModel = $stepModel; } // 建设审核流程 public function addFlow(Request $request) { $data = $request->post(); // 添加审核流程 $flow_result = $this->flowModel->addFlow([ 'name' => $data['name'], 'create_user_id' => $this->getCurrentUserId(), 'create_time' => date('Y-m-d H:i:s'), ]); if (!$flow_result) { return $this->error('建设审核流程失败!'); } // 添加审核办法 $step_data = []; foreach ($data['step'] as $key => $value) { $step_data[] = [ 'flow_id' => $this->flowModel->id, 'name' => $value['name'], 'handler_id' => $value['handler_id'], ]; } $step_result = $this->stepModel->saveAll($step_data); if (!$step_result) { return $this->error('添加审核办法失败!'); } return $this->success('建设审核流程乐成!'); } }
登录后复制
提交审核
用户在提交审核申请后,需要自动触发审核流程,让审核流程最先运行。
// ppcontrollerApplyController.php namespace appcontroller; use appBaseController; use appmodelStepModel; use thinkRequest; class ApplyController extends BaseController { protected $stepModel; public function __construct(StepModel $stepModel) { $this->stepModel = $stepModel; } // 提交审核 public function submitApply(Request $request) { $data = $request->post(); // 获取审核流程的第一办法 $steps = $this->stepModel->getStepListByFlowId($data['flow_id']); if (empty($steps)) { return $this->error('该审核流程未添加办法!'); } $first_step = $steps[0]; // 更新第一办法状态 $update_result = $this->stepModel->updateStepStatus($first_step->id, 1, $this->getCurrentUserId(), date('Y-m-d H:i:s')); if (!$update_result) { return $this->error('更新审核办法状态失败!'); } return $this->success('提交审核乐成!'); } }
登录后复制
审核流程中的审核办法
系统凭证审核流程中界说的办法自动分派审核职员举行审核,并纪录审核效果。
// ppcontrollerApproveController.php namespace appcontroller; use appBaseController; use appmodelStepModel; use thinkRequest; class ApproveController extends BaseController { protected $stepModel; public function __construct(StepModel $stepModel) { $this->stepModel = $stepModel; } // 审核办法 public function approveStep(Request $request) { $data = $request->post(); // 获取目今办法 $step = $this->stepModel->getStepById($data['step_id']); // 更新目今办法状态 $update_result = $this->stepModel->updateStepStatus($data['step_id'], $data['status'], $this->getCurrentUserId(), date('Y-m-d H:i:s')); if (!$update_result) { return $this->error('更新审核办法状态失败!'); } // 获取下一办法 $next_step = $this->stepModel->where('flow_id', $step->flow_id)->where('id', '>', $data['step_id'])->order('id asc')->find(); if (!$next_step) { return $this->success('已审核完成!'); } // 更新下一办法状态 $update_result = $this->stepModel->updateStepStatus($next_step->id, 1, $next_step->handler_id, null); if (!$update_result) { return $this->error('更新审核办法状态失败!'); } return $this->success('审核通过!'); } }
登录后复制
四、总结
通过以上代码示例,我们可以看到ThinkPHP6中很是便捷的实现了审核流程治理功效,通过流程表和办法表的纪录治理,以及模子类的要领操作,我们可以快速、简朴地完成一个完整的审核流程治理系统。
以上就是ThinkPHP6中怎样举行审核流程治理?的详细内容,更多请关注本网内其它相关文章!