2014-09-05
很多人在开发网站的时候往往只是通过简单的js验证,当你一不小心在js中多写了个逗号或者点号,ie6无法识别就直接跳过验证了。其实最安全的做法还是需要在服务端对用户输入的数据做验证的。本人写了个简单的php验证类,含多种验证规则,供大家学习参考。原文链接
[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 'role name "'.$k.'" is not found!';
if($v == true){
if ( !$this->$k($value) ){
if (!isset($validate_err_msg[$kk][$k]))
return 'var '.$key.' in '.$k.' of regular validation failure!';
return $validate_err_msg[$kk][$k];
}
}
}
}
}
}
return true;
}
// 获取规则数组
public function get_role_name(){
return $this->role_name;
}
// 设置属性规则
public function set_role_name($arr){
$this->role_name = array_merge($this->role_name, $arr);
}
// 验证是否为空
public function required($str){
if(trim($str) != "") return true;
return false;
}
// 验证邮件格式
public function email($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)) return true;
else return false;
}
// 验证身份证
public function idcode($str){
if(preg_match("/^/d{14}(/d{1}|/d{4}|(/d{3}[xX]))$/", $str)) return true;
else return false;
}
// 验证http地址
public function http($str){
if(preg_match("/[a-zA-Z]+:////[^/s]*/", $str)) return true;
else return false;
}
//匹配QQ号(QQ号从10000开始)
public function qq($str){
if(preg_match("/^[1-9][0-9]{4,}$/", $str)) return true;
else return 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;
}
}
<?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 'role name "'.$k.'" is not found!';
if($v == true){
if ( !$this->$k($value) ){
if (!isset($validate_err_msg[$kk][$k]))
return 'var '.$key.' in '.$k.' of regular validation failure!';
return $validate_err_msg[$kk][$k];
}
}
}
}
}
}
return true;
}
// 获取规则数组
public function get_role_name(){
return $this->role_name;
}
// 设置属性规则
public function set_role_name($arr){
$this->role_name = array_merge($this->role_name, $arr);
}
// 验证是否为空
public function required($str){
if(trim($str) != "") return true;
return false;
}
// 验证邮件格式
public function email($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)) return true;
else return false;
}
// 验证身份证
public function idcode($str){
if(preg_match("/^/d{14}(/d{1}|/d{4}|(/d{3}[xX]))$/", $str)) return true;
else return false;
}
// 验证http地址
public function http($str){
if(preg_match("/[a-zA-Z]+:////[^/s]*/", $str)) return true;
else return false;
}
//匹配QQ号(QQ号从10000开始)
public function qq($str){
if(preg_match("/^[1-9][0-9]{4,}$/", $str)) return true;
else return 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;
}
}
调用方法
[php]
<?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;
}
<?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;
}
当然,如果你觉得验证无法满足你的需求,您还可以创建子类扩展您的方法
[php]
<?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;
}
}
}
<?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;
}
}
}
1
CI框架连接数据库配置操作以及多数据库操作
09-05
2
asp 简单读取数据表并列出来 ASP如何快速从数据库读取大量数据
05-17
3
C语言关键字及其解释介绍 C语言32个关键字详解
04-05
4
C语言中sizeof是什么意思 c语言里sizeof怎样用法详解
04-26
5
PHP中的魔术方法 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep,
09-05
6
将视频设置为Android手机开机动画的教程
12-11
7
PHP中的(++i)前缀自增 和 (i++)后缀自增
09-05
8
最简单的asp登陆界面代码 asp登陆界面源代码详细介绍
04-12
常用dos命令及语法
2014-09-27
PHP中include和require区别之我见
2014-09-05
如何安装PHPstorm并配置方法教程 phpstorm安装后要进行哪些配置
2017-05-03
php递归返回值的问题
2014-09-05
单片机编程好学吗?单片机初学者怎样看懂代码
2022-03-21
PHP 教程之如何使用BLOB存取图片信息实例
2014-09-05
学ug编程如何快速入门?
2022-03-17
PHP数组函数array
2014-09-05
学习使用C语言/C++编程的7个步骤!超赞~
2022-03-20
零基础的初学者怎样学习java,或者应该先学什么?
2022-03-21
坦克沙盒游戏手机版(坦克物理模拟)下载v9.0 安卓版
其它手游 241.7MB
下载
太空人抽卡对决手机版下载v1.6 安卓版
其它手游 77.61MB
下载
棕熊露营旅行游戏下载v1.1.0 安卓版
其它手游 32.94MB
下载
回家的猫游戏下载v2.5.18 安卓版
角色扮演 105.86MB
下载
蜗牛鲍勃3游戏(snail bob 3)下载v1.0.34 安卓版
其它手游 96.55MB
下载
snail bob3最新版下载v1.0.34 安卓版
其它手游 96.55MB
下载
西梅小说手机版v1.0
其它手游 24.36MB
下载
超级舰队3k破解版下载v10.3 安卓最新版
策略塔防 100.64MB
下载房间的秘密2起点官方版下载v1.2.4.df926432 安卓版
下载
葫芦娃tv版小y游戏下载v3.0.8 安卓版
下载
葫芦娃tv版渠道游戏下载v3.0.8 安卓版
下载
足球大玩家手游下载v1.224.6 安卓最新版
下载
辉烬embers手游官方下载v1.0.0 安卓版
下载
代号辉烬手游下载v1.0.0 安卓版
下载
远光84手游下载v1.1.1.3.1612300 安卓版
下载
逆战助手app下载v3.15.0 安卓版
下载