一个可扩展的php验证类
来源:互联网 发布:讯龙数据恢复 免费 编辑:程序博客网 时间:2024/05/17 01:09
demo:
require_once('./Validator.class.php');$data = array( 'nickname' => 'heno' , 'realname' => 'steven', 'age' => 25, 'mobile' => '1521060426');$validator = new Validator($data);$validator->setRule('nickname', 'required');$validator->setRule('realname', array('length' => array(1,6), 'required'));$validator->setRule('age', array('required', 'digit'));$validator->setRule('mobile', array('mobile'));$result = $validator->validate();var_dump($result);var_dump($validator->getResultInfo());
Validator.class.php中代码
<?php/** * Validator 数据验证类 * @package library * @category library * @author Steven * @version 1.0 *//** * Validator 数据验证类 * @package library * @category library * @author Steven * @version 1.0 */class Validator {/** * 待校验数据 * @var array */private $_data;/** * 校验规则 * @var array */private $_ruleList = null;/** * 校验结果 * @var bool */private $_result = null;/** * 校验数据信息 * @var array */private $_resultInfo = array();/** * 构造函数 * @param array $data 待校验数据 */public function __construct($data = null){if ($data) {$this->_data = $data;}}/** * 设置校验规则 * @param string $var 带校验项key * @param mixed $rule 校验规则 * @return void */public function setRule($var, $rule){$this->_ruleList[$var] = $rule;}/** * 检验数据 * @param array $data * <code> * $data = array('nickname' => 'heno' , 'realname' => 'steven', 'age' => 25); * $validator = new Validator($data); * $validator->setRule('nickname', 'required'); * $validator->setRule('realname', array('lenght' => array(1,4), 'required')); * $validator->setRule('age', array('required', 'digit')); * $result = $validator->validate(); * var_dump($validator->getResultInfo()); * </code> * @return bool */public function validate($data = null){$result = true;/* 如果没有设置校验规则直接返回 true */if ($this->_ruleList === null || !count($this->_ruleList)) {return $result;}/* 已经设置规则,则对规则逐条进行校验 */foreach ($this->_ruleList as $ruleKey => $ruleItem) {/* 如果检验规则为单条规则 */if (!is_array($ruleItem)) {$ruleItem = trim($ruleItem);if (method_exists($this, $ruleItem)) {/* 校验数据,保存校验结果 */$tmpResult = $this->$ruleItem($ruleKey);if (!$tmpResult) {$this->_resultInfo[$ruleKey][$ruleItem] = $tmpResult;$result = false;}}continue;}/* 校验规则为多条 */foreach ($ruleItem as $ruleItemKey => $rule) {if (!is_array($rule)) {$rule = trim($rule);if (method_exists($this, $rule)) {/* 校验数据,设置结果集 */$tmpResult = $this->$rule($ruleKey);if (!$tmpResult) {$this->_resultInfo[$ruleKey][$rule] = $tmpResult;$result = false;}}} else {if (method_exists($this, $ruleItemKey)) {/* 校验数据,设置结果集 */$tmpResult = $this->$ruleItemKey($ruleKey, $rule);if (!$tmpResult) {$this->_resultInfo[$ruleKey][$ruleItemKey] = $tmpResult;$result = false;}}}}}return $result;}/** * 获取校验结果数据 * @return [type] [description] */public function getResultInfo(){return $this->_resultInfo;}/** * 校验必填参数 * @param string $varName 校验项 * @return bool */public function required($varName) {$result = false;if (is_array($this->_data) && isset($this->_data[$varName])) {$result = true;}return $result;}/** * 校验参数长度 * * @param string $varName 校验项 * @param array $lengthData array($minLen, $maxLen) * @return bool */public function length($varName, $lengthData){$result = true;/* 如果该项没有设置,默认为校验通过 */if ($this->required($varName)) {$varLen = mb_strlen($this->_data[$varName]);$minLen = $lengthData[0];$maxLen = $lengthData[1];if ($varLen < $minLen || $varLen > $maxLen) {$result = true;}}return $result;}/** * 校验邮件 * @param string $varName 校验项 * @return bool */public function email($varName){$result = true;/* 如果该项没有设置,默认为校验通过 */if ($this->required($varName)) {$email = trim($this->_data[$varName]);if (preg_match('/^[-\w]+?@[-\w.]+?$/', $email)) {$result = false;}}return $result;}/** * 校验手机 * @param string $varName 校验项 * @return bool */public function mobile($varName){$result = true;/* 如果该项没有设置,默认为校验通过 */if ($this->required($varName)) {$mobile = trim($this->_data[$varName]);if (!preg_match('/^1[3458]\d{10}$/', $mobile)) {$result = false;}}return $result;}/** * 校验参数为数字 * @param string $varName 校验项 * @return bool */public function digit($varName){$result = false;if ($this->required($varName) && is_numeric($this->_data[$varName])) {$result = true;}return $result;}/** * 校验参数为身份证 * @param string $varName 校验项 * @return bool */public function ID($ID){}/** * 校验参数为URL * @param string $varName 校验项 * @return bool */public function url($url){$result = true;/* 如果该项没有设置,默认为校验通过 */if ($this->required($varName)) {$url = trim($this->_data[$varName]);if(!preg_match('/^(http[s]?::)?\w+?(\.\w+?)$/', $url)) {$result = false;}}return $result;}}?>
0 0
- 一个可扩展的php验证类
- Flight 一个可扩展的PHP微框架
- Retrofit--创建一个可扩展的客户端
- 【PHP】一个简单的验证码类
- 一个很好的PHP验证类
- php 一个验证码类的改写
- 一个漂亮的php验证码类
- 一个PHP实现的验证码类
- Riak的一个PHP扩展
- 一个简单的PHP扩展
- 验证码制作之四:位数可改变内容可扩展的验证码产生方法
- 创建可重用、可扩展和可伸缩的 PHP 代码
- php实现一段非常有意思的代码(可扩展)
- 扩展的验证工具类
- HP加易语言数据库,全源码制作的网络验证,可运营,可自行扩展
- 编写一个简单的php扩展
- PHP扩展开发:一个简单的例子
- 如何编写一个PHP的C扩展
- - (void)onGetAddrResult:(BMKSearch *)searcher result:(BMKAddrInfo *)result errorCode:(int)error不回调的问
- QT 正则表达式
- UVa 539 & POJ 2258 - The Settlers of Catan
- leetcode之Jump Game && Jump Game II
- Node.js可以做什么?
- 一个可扩展的php验证类
- Oracle学习笔记安装篇之在Redhat Enterprise Linux 7.0 x86_64下安装Oracle11g R2
- 总结stm32的printf相关知识
- Android下抓包流程
- 开启技术人生
- 黑马程序员_java中的多线程
- IIS tomcat共用80端口解决一个IP多个域名:使用Nginx反向代理方式使两者兼容
- [设计模式]--创建型模式
- monkey --pkg-whitelist