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

很多人在开发网站的时候往往只是通过简单的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;
  }
 }
}

 

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

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),