首页 > php教程 > php手册 > 简单编写php验证类,教你如何写好php程序(含多种验证规则)

简单编写php验证类,教你如何写好php程序(含多种验证规则)

WBOY
发布: 2016-06-13 10:56:59
原创
793 人浏览过

很多人在开发网站的时候往往只是通过简单的js验证,当你一不小心在js中多写了个逗号或者点号,ie6无法识别就直接跳过验证了。其实最安全的做法还是需要在服务端对用户输入的数据做验证的。本人写了个简单的php验证类,含多种验证规则,供大家学习参考。原文链接


[php] 
/**
 * 用户输入规则验证类
 * author   HaiNing Zhang
 * date     2013-05-23
 */ 
class Validate{ 
    // 验证规则  
    private $role_name = array( 
            // 验证是否为空  
            'required', 
 
            // 匹配邮箱  
            'email', 
 
            // 匹配身份证  
            'idcode', 
 
            // 匹配数字  
            'number', 
 
            // 匹配http地址  
            'http', 
 
            // 匹配qq号  
            'qq', 
 
            //匹配中国邮政编码  
            'postcode', 
 
            //匹配ip地址  
            'ip', 
 
            //匹配电话格式  
            'telephone', 
 
            // 匹配手机格式  
            'mobile', 
 
            //匹配26个英文字母  
            'en_word', 
 
            // 匹配只有中文  
            'cn_word', 
 
            // 验证账户(字母开头,由字母数字下划线组成,4-20字节)  
            'user_account', 
        ); 
 
    /**
     * [验证函数]
     * @param  [array] $data                [用户要验证的数据]
     * @param  [array] $validate_role       [验证规则]
     * @param  [array] $validate_err_msg    [错误信息提示]
     * @return [bool]                       [成功返回true, 失败返回错误信息]
    */ 
    public function verify($data, $validate_role, $validate_err_msg=''){ 
        if(empty($data)) return false; 
        if(empty($validate_role)) return false; 
        foreach ($data as $key => $value) { 
            $key = strtolower($key); 
            foreach ($validate_role as $kk => $vv) { 
                $kk = strtolower($kk); 
                if($key == $kk){ 
                    foreach ($vv as $k => $v) { 
                        $k = strtolower($k); 
                        if( !in_array($k, $this->role_name)) return '未找到角色名称“'.$k.'”!'; 
                        if($v == true){ 
                            if ( !$this->$k($value) ){ 
                                if (!isset($validate_err_msg[$kk][$k])) 
                                返回'var'.$key。'在“.$k”中。定期验证失败!'; 
                                返回$validate_err_msg[$kk][$k]; 
                            } 
                        } 
                    } 
                } 
            } 
        } 
        返回真; 
    } 
 
    // 获取规则储备  
    公共函数 get_role_name(){ 
        返回 $this->role_name; 
    } 
 
    // 属性设置规则  
    公共函数 set_role_name($arr){ 
        $this->role_name = array_merge($this->role_name, $arr); 
    } 
 
    // 验证是否为空  
    需要公共函数($str){ 
        if(trim($str) != "") 返回 true; 
        返回假; 
    } 
 
    // 验证邮件格式  
    公共函数电子邮件($str){ 
        if(preg_match("/^([a-zA-Z0-9] [_|_|.]?)*[a-zA-Z0-9] @([a-zA-Z0-9] [_| _|.]?)*[a-zA-Z0-9] .[a-zA-Z]{2,3}$/", $str)) 返回 true; 
        否则返回 false; 
    } 
 
    // 验证身份证
    公共函数 idcode($str){ 
        if(preg_match("/^d{14}(d{1}|d{4}|(d{3}[xX]))$/", $str)) 返回 true; 
        否则返回 false; 
    } 
 
    // 验证http地址  
    公共函数http($str){ 
        if(preg_match("/[a-zA-Z] ://[^s]*/", $str)) 返回 true; 
        否则返回 false; 
    } 
 
    //匹配QQ号(QQ号从10000开始)  
    公共函数 qq($str){ 
        if(preg_match("/^[1-9][0-9]{4,}$/", $str)) 返回 true; 
        否则返回 false; 
    } 
 
    //匹配中国邮政编码  
    public function postcode($str){ 
        if(preg_match("/^[1-9]d{5}$/", $str)) return true; 
        else return false; 
    } 
 
    //匹配ip地址  
    public function ip($str){ 
        if(preg_match("/^d{1,3}.d{1,3}.d{1,3}.d{1,3}$/", $str)) return true; 
        else return false; 
    } 
 
    // 匹配电话格式  
    public function telephone($str){ 
        if(preg_match("/^d{3}-d{8}$|^d{4}-d{7}$/", $str)) return true; 
        else return false; 
    } 
 
    // 匹配手机格式  
    public function mobile($str){ 
        if(preg_match("/^(13[0-9]|15[0-9]|18[0-9])d{8}$/", $str)) return true; 
        else return false; 
    } 
 
    // 匹配26个英文字母  
    public function en_word($str){ 
        if(preg_match("/^[A-Za-z] $/", $str)) return true; 
        else return false; 
    } 
 
    // 匹配只有中文  
    public function cn_word($str){ 
        if(preg_match("/^[x80-xff] $/", $str)) return true; 
        else return false; 
    } 
 
    // 验证账户(字母开头,由字母数字下划线组成,4-20字节)  
    public function user_account($str){ 
        if(preg_match("/^[a-zA-Z][a-zA-Z0-9_]{3,19}$/", $str)) return true; 
        else return false; 
    } 
 
    // 验证数字  
    public function number($str){ 
        if(preg_match("/^[0-9] $/", $str)) return true; 
        else return false; 
    } 

/**
 * 用户输入规则验证类
 * author  HaiNing Zhang
 * date  2013-05-23
 */
class Validate{
 // 验证规则
 private $role_name = array(
   // 验证是否为空
   'required',

   // 匹配邮箱
   'email',

   // 匹配身份证
   'idcode',

   // 匹配数字
   'number',

   // 匹配http地址
   'http',

   // 匹配qq号
   'qq',

   //匹配中国邮政编码
   'postcode',

   //匹配ip地址
   'ip',

   //匹配电话格式
   'telephone',

   // 匹配手机格式
   'mobile',

   //匹配26个英文字母
   'en_word',

   // 匹配只有中文
   'cn_word',

   // 验证账户(字母开头,由字母数字下划线组成,4-20字节)
   'user_account',
  );

 /**
  * [验证函数]
  * @param  [array] $data              [用户要验证的数据]
  * @param  [array] $validate_role     [验证规则]
  * @param  [array] $validate_err_msg  [错误信息提示]
  * @return [bool]                    [成功返回true, 失败返回错误信息]
 */
 公共函数验证($data, $validate_role, $validate_err_msg=''){
  if(empty($data)) return false;
  if(empty($validate_role)) return false;
  foreach ($data as $key => $value) {
   $key = strtolower($key);
   foreach ($validate_role as $kk => $vv) {
    $kk = strtolower($kk);
    if($key == $kk){
     foreach ($vv as $k => $v) {
      $k = strtolower($k);
      if( !in_array($k, $this->role_name)) return '未找到角色名称“'.$k.'”!';
      if($v == true){
       if ( !$this->$k($value) ){
        if (!isset($validate_err_msg[$kk][$k]))
        返回'var'.$key。'在“.$k”中。定期验证失败!';
        返回 $validate_err_msg[$kk][$k];
       }
      }
     }
    }
   }
  }
  返回真;
 }

 // 获取规则储备
 公共函数 get_role_name(){
  return $this->role_name;
 }

 // 设置属性规则
 公共函数 set_role_name($arr){
  $this->role_name = array_merge($this->role_name, $arr);
 }

 //验证是否为空
 需要公共函数($str){
  if(trim($str) != "") return true;
  返回错误;
 }

 // 验证邮件格式
 公共函数电子邮件($str){
  if(preg_match("/^([a-zA-Z0-9] [_|_|.]?)*[a-zA-Z0-9] @([a-zA-Z0-9] [_| _|.]?)*[a-zA-Z0-9] .[a-zA-Z]{2,3}$/", $str)) 返回 true;
  否则返回 false;
 }

 // 验证身份证
 公共函数 idcode($str){
  if(preg_match("/^d{14}(d{1}|d{4}|(d{3}[xX]))$/", $str)) return true;
  否则返回 false;
 }

 //验证http地址
 公共函数http($str){
  if(preg_match("/[a-zA-Z] ://[^s]*/", $str)) return true;
  否则返回 false;
 }

 //匹配QQ号(QQ号从10000开始)
 公共函数 qq($str){
  if(preg_match("/^[1-9][0-9]{4,}$/", $str)) return true;
  否则返回 false;
 }

 //匹配中国邮政编码
 公共函数邮政编码($str){
  if(preg_match("/^[1-9]d{5}$/", $str)) return true;
  否则返回 false;
 }

 //匹配ip地址
 公共函数 ip($str){
  if(preg_match("/^d{1,3}.d{1,3}.d{1,3}.d{1,3}$/", $str)) return true;
  否则返回 false;
 }

 // 匹配电话格式
 公共职能电话($str){
  if(preg_match("/^d{3}-d{8}$|^d{4}-d{7}$/", $str)) return true;
  否则返回 false;
 }

 // 匹配手机格式
 公共功能移动($str){
  if(preg_match("/^(13[0-9]|15[0-9]|18[0-9])d{8}$/", $str)) return true;
  否则返回 false;
 }

 //匹配26个英文字母
 公共函数 en_word($str){
  if(preg_match("/^[A-Za-z] $/", $str)) return true;
  否则返回 false;
 }

 // 只匹配中文
 公共函数 cn_word($str){
  if(preg_match("/^[x80-xff] $/", $str)) return true;
  否则返回 false;
 }

 // 验证账户(字母开头,由字母数字下划线组成,4-20字节)
 public function user_account($str){
  if(preg_match("/^[a-zA-Z][a-zA-Z0-9_]{3,19}$/", $str)) return true;
  else return false;
 }

 // 验证数字
 public function number($str){
  if(preg_match("/^[0-9] $/", $str)) return true;
  else return false;
 }
}
调用方法


[php] 
require('model/Validate.php'); 
$data = array( 
    "username"=>'ningofaura@gmail.com', 
    "qq"=>'593084029', 
    "nickname"=>'张海宁', 
    "id"=>'24', 
    ); 
$validate_role = array( 
    'username'=>array( 
        'required'=>true, 
        'email'=>true, 
        ), 
    'qq'=>array( 
        'required'=>true, 
        'qq'=>true, 
        ), 
    'nickname'=>array( 
        'required'=>true, 
        ), 
    'id'=>array( 
        'required'=>true, 
        'number'=>true, 
        ), 
    ); 
 
$validate_err_msg = array( 
    'username'=>array( 
        'required'=>"用户名不能为空", 
        'email'=>"邮箱格式不正确", 
        ), 
    'qq'=>array( 
        'required'=>"qq不能为空", 
        'qq'=>"qq格式不正确", 
        ), 
    'nickname'=>array( 
        'required'=>"昵称不能为空", 
        ), 
    'id'=>array( 
        'required'=>"id不能为空", 
        'number'=>"不是数字", 
        ), 
    ); 
$Validate = new Validate(); 
$rt = $Validate->verify($data, $validate_role, $validate_err_msg); 
if ($rt !== true){ 
    echo $rt; 
    exit; 

require('model/Validate.php');
$data = 数组(
    "用户名"=>'ningofaura@gmail.com',
    "qq"=>'593084029',
    "昵称"=>'张海宁',
    "id"=>'24',
    );
$validate_role = 数组(
    '用户名'=>数组(
        '必需'=>true,
        '电子邮件'=>true,
        ),
    'qq'=>数组(
        '必需'=>true,
        'qq'=>true,
        ),
    '昵称'=>数组(
        '必需'=>true,
        ),
    'id'=>数组(
        '必需'=>true,
        '数字'=>true,
        ),
    );

$validate_err_msg = 数组(
    '用户名'=>数组(
        'required'=>"用户名不能为空",
        'email'=>"邮箱格式不正确",
        ),
    'qq'=>数组(
        'required'=>"qq不能为空",
        'qq'=>"qq格式不正确",
        ),
    '昵称'=>数组(
        'required'=>"昵称不能为空",
        ),
    'id'=>数组(
        'required'=>"id 不能为空",
        'number'=>"不是数字",
        ),
    );
$Validate = new Validate();
$rt = $Validate->verify($data, $validate_role, $validate_err_msg);
if ($rt !== true){
    回声 $rt;
    退出;
}

当然,如果您觉得验证无法满足您的需求,您还可以创建子类扩展您的方法


[php]
/**
 * 用户数据库异步验证
 * author   HaiNing Zhang
 * date     2013-05-23
 */ 
class AjaxValidate extends Validate{ 
    private $role_name = array( 
            // 验证用户名是否存在  
            'is_username', 
 
            // 验证昵称是否存在  
            'is_nickname', 
        ); 
 
    private $db; 
 
    public function __construct(){ 
        $this->db = &load_system("Database"); 
        $this->set_role_name($this->role_name); 
    } 
 
    // 判断用户名是否可以注册(防止用户名重复)  
    public function is_username($username){ 
        $_username = $this->db->filter('s', $username); 
        $sql = "select id from user where username =".$_username; 
        if($this->db->num_rows($sql)){ 
            return false; 
        }else{ 
            return true; 
        } 
    } 
 
    // 判断昵称是否可用(防止昵称重复)  
    public function is_nickname($nickname){ 
        $_nickname = $this->db->filter('s', $nickname); 
        $sql = "select id from user where nickname =".$_nickname; 
        if($this->db->num_rows($sql)){ 
            return false; 
        }else{ 
            return true; 
        } 
    } 

/**
 * 用户数据库异步验证
 * author HaiNing Zhang
 * date  2013-05-23
 */
class AjaxValidate extends Validate{
 private $role_name = array(
   // 验证用户名是否存在
   'is_username',

   // 验证昵称是否存在
   'is_nickname',
  );

 private $db;

 public function __construct(){
  $this->db = &load_system("Database");
  $this->set_role_name($this->role_name);
 }

 // 判断用户名是否可以注册(防止用户名重复)
 public function is_username($username){
  $_username = $this->db->filter('s', $username);
  $sql = "select id from user where username =".$_username;
  if($this->db->num_rows($sql)){
   return false;
  }else{
   return true;
  }
 }

 // 判断昵称是否可用(防止昵称重复)
 public function is_nickname($nickname){
  $_nickname = $this->db->filter('s', $nickname);
  $sql = "select id from user where nickname =".$_nickname;
  if($this->db->num_rows($sql)){
   return false;
  }else{
   return true;
  }
 }
}

 

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板