数据校验类Validator -有PHP,C#,ASP和JS版

 
表单的验证一直是网页设计者头痛的问题,表单验证类 Validator就是为解决这个问题而写的,旨在使设计者从纷繁复杂的表单验证中解放出来,把精力集中于网页的设计和功能上的改进上。 

Validator是基于JavaScript技术的伪静态类和对象的自定义属性,可以对网页中的表单项输入进行相应的验证,允许同一页面中同时验证多个表单,熟悉接口之后也可以对特定的表单项甚至仅仅是某个字符串进行验证。因为是伪静态类,所以在调用时不需要实例化,直接以"类名+.语法+属性或方法名"来调用。此外,Validator还提供3种不同的错误提示模式,以满足不同的需要。 

Validator目前可实现的验证类型有: 
[JavaScript] 版
Validator目前可实现的验证类型有: 
1.是否为空;
2.中文字符;
3.双字节字符
4.英文;
5.数字;
6.整数;
7.实数;
8.Email地址;
9.使用HTTP协议的网址;
10.电话号码;
11.货币;
12.手机号码;
13.邮政编码;
14.身份证号码(1.05增强);
15.QQ号码;
16.日期;
17.符合安全规则的密码;
18.某项的重复值;
19.两数的关系比较;
20.判断输入值是否在(n, m)区间;
21.输入字符长度限制(可按字节比较);
22.对于具有相同名称的单选按钮的选中判断;
23.限制具有相同名称的多选按钮的选中数目;
24.自定义的正则表达式验证; 
25.文件上传格式过滤(1.04)
运行环境(客户端): 
在Windows Server 2003下用IE6.0+SP1和Mozilla Firefox 1.0测试通过;
在Lunix RedHat 9下的Netscape测试通过; 

对于客户端的表单验证,这个基于JavaScript编写的Validator基本上都可以满足,具体可以下载CHM文件:

1、 ASP 版本
程序代码 程序代码
<%@Language="VBScript" CodePage="936"%>
<%
'Option Explicit
Class Validator
'*************************************************
'    Validator for ASP beta 3 服务器端脚本
'    code by 我佛山人
'    wfsr@cunite.com
'*************************************************
    Private Re
    Private ICodeName
    Private ICodeSessionName

    Public Property Let CodeName(ByVal PCodeName)
        ICodeName = PCodeName
    End Property

    Public Property Get CodeName()
        CodeName = ICodeName
    End Property

    Public Property Let CodeSessionName(ByVal PCodeSessionName)
        ICodeSessionName = PCodeSessionName
    End Property

    Public Property Get CodeSessionName()
        CodeSessionName = ICodeSessionName
    End Property

    Private Sub Class_Initialize()
        Set Re = New RegExp
        Re.IgnoreCase = True
        Re.Global = True
        Me.CodeName = "vCode"
        Me.CodeSessionName = "vCode"
    End Sub

    Private Sub Class_Terminate()
        Set Re = Nothing
    End Sub

    Public Function IsEmail(ByVal Str)
        IsEmail = Test("^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*{logContent}quot;, Str)
    End Function

    Public Function IsUrl(ByVal Str)
        IsUrl = Test("^http:[A-Za-z0-9]+/.[A-Za-z0-9]+[//=/?%/-&_~`@[/]/':+!]*([^<>""])*{logContent}quot;, Str)
    End Function

    Public Function IsNum(ByVal Str)
        IsNum= Test("^/d+{logContent}quot;, Str)
    End Function

    Public Function IsQQ(ByVal Str)
        IsQQ = Test("^[1-9]/d{4,8}{logContent}quot;, Str)
    End Function

    Public Function IsZip(ByVal Str)
        IsZip = Test("^[1-9]/d{5}{logContent}quot;, Str)
    End Function

    Public Function IsIdCard(ByVal Str)
        IsIdCard = Test("^/d{15}(/d{2}[A-Za-z0-9])?{logContent}quot;, Str)
    End Function

    Public Function IsChinese(ByVal Str)
        IsChinese = Test("^[/u0391-/uFFE5]+{logContent}quot;, Str)
    End Function

    Public Function IsEnglish(ByVal Str)
        IsEnglish = Test("^[A-Za-z]+{logContent}quot;, Str)
    End Function

    Public Function IsMobile(ByVal Str)
        IsMobile = Test("^((/(/d{3}/))|(/d{3}/-))?13/d{9}{logContent}quot;, Str)
    End Function

    Public Function IsPhone(ByVal Str)
        IsPhone = Test("^((/(/d{3}/))|(/d{3}/-))?(/(0/d{2,3}/)|0/d{2,3}-)?[1-9]/d{6,7}{logContent}quot;, Str)
    End Function

    Public Function IsSafe(ByVal Str)
        IsSafe = (Test("^(([A-Z]*|[a-z]*|/d*|[-_/~!@#/$%/^&/*/./(/)/[/]/{/}<>/?/'/""]*)|.{0,5})$|/s", Str) = False)
    End Function

    Public Function IsNotEmpty(ByVal Str)
        IsNotEmpty = LenB(Str) > 0
    End Function

    Public Function IsDateFormat(ByVal Str, ByVal Format)
        IF Not IsDate(Str) Then
            IsDateFormat = False
            Exit Function
        End IF

        IF Format = "YMD" Then
            IsDateFormat = Test("^((/d{4})|(/d{2}))([-./])(/d{1,2})/4(/d{1,2}){logContent}quot;, Str)
        Else 
            IsDateFormat = Test("^(/d{1,2})([-./])(/d{1,2})//2((/d{4})|(/d{2})){logContent}quot;, Str)
        End IF
    End Function

    Public Function IsEqual(ByVal Src, ByVal Tar)
        IsEqual = (Src = Tar)
    End Function

    Public Function Compare(ByVal Op1, ByVal Operator, ByVal Op2)
        Compare = False
        IF Dic.Exists(Operator) Then
            Compare = Eval(Dic.Item(Operator))
            Elseif IsNotEmpty(Op1) Then
                Compare = Eval(Op1 & Operator & Op2 )
        End IF
    End Function

    Public Function Range(ByVal Src, ByVal Min, ByVal Max)
        Min = CInt(Min) : Max = CInt(Max)
        Range = (Min < Src And Src < Max)
    End Function

    Public Function Group(ByVal Src, ByVal Min, ByVal Max)
        Min = CInt(Min) : Max = CInt(Max)
        Dim Num : Num = UBound(Split(Src, ",")) + 1
        Group = Range(Num, Min - 1, Max + 1)
    End Function

    Public Function Custom(ByVal Str, ByVal Reg)
        Custom = Test(Reg, Str)
    End Function

    Public Function Limit(ByVal Str, ByVal Min, ByVal Max)
        Min = CInt(Min) : Max = CInt(Max)
        Dim L : L = Len(Str)
        Limit = (Min <= L And L <= Max)
    End Function

    Public Function LimitB(ByVal Str, ByVal Min, ByVal Max)
        Min = CInt(Min) : Max = CInt(Max)
        Dim L : L =bLen(Str)
        LimitB = (Min <= L And L <= Max)
    End Function

    Private Function Test(ByVal Pattern, ByVal Str)
        If IsNull(Str) or IsEmpty(Str) Then
            Test = False
        Else
            Re.Pattern = Pattern
            Test = Re.Test(CStr(Str))
        End If
    End Function

    Public Function bLen(ByVal Str)
        bLen = Len(Replace(Str, "[^/x00-/xFF]", ".."))
    End Function

    Private Function Replace(ByVal Str, ByVal Pattern, ByVal ReStr)
        Re.Pattern = Pattern
        Replace =     Re.Replace(Str, ReStr)
    End Function

    Private Function B2S(ByVal iStr) 
        Dim reVal : reVal= ""
        Dim i, Code, nCode
        For i = 1 to LenB(iStr) 
            Code = AscB(MidB(iStr, i, 1)) 
            IF Code < &h80 Then 
                reVal = reVal & Chr(Code) 
            Else 
                nCode = AscB(MidB(iStr, i+1, 1)) 
                reVal = reVal & Chr(CLng(Code) * &h100 + CInt(nCode)) 
                i = i + 1 
            End IF 
        Next
        B2S = reVal 
    End Function

    Public Function SafeStr(ByVal Name)
        If IsNull(Name) or IsEmpty(Name) Then
            SafeStr = False
        Else
            SafeStr = Replace(Trim(Name), "(/s*and/s*/w*=/w*)|['%&<>=]", "")
        End If
    End Function

    Public Function SafeNo(ByVal Name)
        If IsNull(Name) or IsEmpty(Name) Then
            SafeNo = 0
        Else
            SafeNo = (Replace(Trim(Name), "^[/D]*(/d+)[/D/d]*{logContent}quot;, ""))
        End If
    End Function

    Public Function IsValidCode()
        IsValidCode = ((Request.Form(Me.CodeName) = Session(Me.CodeSessionName)) AND Session(Me.CodeSessionName) <> "")
    End Function

    Public Function IsValidPost()
        Dim Url1 : Url1 = Cstr(Request.ServerVariables("HTTP_REFERER"))
        Dim Url2 : Url2 = Cstr(Request.ServerVariables("SERVER_NAME"))
        IsValidPost = (Mid(Url1, 8, Len(Url2)) = Url2)
    End Function

End Class
%>


2、PHP版本
程序代码 程序代码

 <title>表单验证类 Validator for PHP β</title>
 <style>
 body,td{font:normal 12px Verdana;color:#333333}
 input,textarea,select,td{font:normal 12px Verdana;color:#333333;border:1px solid #999999;background:#ffffff}
 table{border-collapse:collapse;}
 td{padding:3px}
 input{height:20;}
 textarea{width:80%;height:50px;overfmin:auto;}
 form{display:inline}
 </style>
 <table align="center">
<form action="Validator.php" method="post">
  <tr>
   <td>提示模式:</td><td>
   <select name="emode">
   <option value="1">警告提示框(客户端)</option>
   <option value="2">提示框加红色文字提示</option>
   <option value="3">附加红色提示</option>
   <option value="4">警告提示框(服务器端)</option>
   <option value="5">文字提示(服务器端)</option>
   </select></td>
  </tr>
  <tr>
   <td>真实姓名:</td><td><input name="Name"></td>
  </tr>
  <tr>
   <td>英文名:</td><td><input name="Nick"></td>
  </tr>
    <tr>
   <td>主页:</td><td><input name="Homepage"></td>
  </tr>
  <tr>
   <td>密码:</td><td><input name="Password"></td>
  </tr>
  <tr>
   <td>重复:</td><td><input name="Repeat"></td>
  </tr>
  <tr>
   <td>信箱:</td><td><input name="Email"></td>
  </tr>
    <tr>
   <td>信箱:</td><td><input name="Email1"></td>
  </tr>
  <tr>
   <td>QQ:</td><td><input name="QQ"></td>
  </tr>
    <tr>
   <td>身份证:</td><td><input name="Card"></td>
  </tr>
  <tr>
   <td>年龄:</td><td><input name="Year"></td>
  </tr>
   <tr>
   <td>年龄1:</td><td><input name="Year1"></td>
  </tr>
   <tr>
   <td>电话:</td><td><input name="Phone"></td>
  </tr>
   <tr>
   <td>手机:</td><td><input name="Mobile"></td>
  </tr>
     <tr>
   <td>生日:</td><td><input name="Birthday"></td>
  </tr>
   <tr>
   <td>邮政编码:</td><td><input name="Zip"></td>
  </tr>
  <tr>
   <td>邮政编码:</td><td><input name="Zip1"></td>
  </tr>
  <tr>
   <td>操作系统:</td><td><select name="OS"><option value="">选择您所用的操作系统</option><option value="Win98">Win98</option><option value="Win2k">Win2k</option><option value="WinXP">WinXP</option></select></td>
  </tr>
  <tr>
   <td>所在省份:</td><td>广东<input name="Province" value="1" type="radio">陕西<input name="Province" value="2" type="radio">浙江<input name="Province" value="3" type="radio">江西<input name="Province" value="4" type="radio"></td>
  </tr>
  <tr>
   <td>爱好:</td><td>运动<input name="Favorite" value="1" type="checkbox">上网<input name="Favorite" value="2" type="checkbox">听音乐<input name="Favorite" value="3" type="checkbox">看书<input name="Favorite" value="4" type="checkbox"></td>
  </tr>
   <td>自我介绍:</td><td><textarea name="Description">中文是一个字</textarea></td>
  </tr>
     <td>自传:</td><td><textarea name="History">中文是两个字节t</textarea></td>
  </tr>
  <tr>
   <td colspan="2"><input name="Submit" type="submit" value="确定提交"></td>
  </tr>
  </form>
 </table>
 <script defer>
 /*************************************************
    Validator for PHP  β 客户端脚本
    code by 我佛山人
    wfsr@cunite.com
     http://www.cunite.com
*************************************************/
 function dispError(items, messages, mode, separator){
    var iArray = items.split(separator);
    for(var i=iArray.length-1;i>=0;i--)
        iArray[i] = getObj(iArray[i]);
    messages = ("以下原因导致提交失败:/t/t/t/t" + separator + messages).split(separator);
    switch(mode){
        case 2 :
            for(i=iArray.length-1;i>=0;i--)
                iArray[i].style.color = "red";
        case 1 :
            alert(messages.join("/n"));
            iArray[0].focus();
            break;
        case 3 :
            for(i=iArray.length-1;i>=0;i--){
                try{
                    var span = document.createElement("SPAN");
                    span.id = "__ErrorMessagePanel";
                    span.style.color = "red";
                    iArray[i].parentNode.appendChild(span);
                    span.innerHTML = messages[i+1].replace(//d+:/,"*");
                }
                catch(e){alert(e.description);}
            }
            iArray[0].focus();
            break;
    }
 }

 function getObj(name){
    var objs = document.getElementsByName(name);
    return objs[objs.length -1];
 }
</script>
<?php
class Validator{
/*************************************************
    Validator for PHP  β 服务器端脚本
    code by 我佛山人
    wfsr@cunite.com
     http://www.cunite.com
*************************************************/
    var $submit;
    var $error_item, $error_message, $error_mode, $error_no;
    function Validator($submit_name = "Submit", $mode = 5){
        $this->submit = $submit_name;
        $this->error_mode = $mode;
        $this->error_no = 1;
    }

    function Validate($arr){
        if(! isset($_POST[$this->submit])) return false;
        $this->error_mode = $_POST["emode"];
        echo "<script defer>document.getElementsByName(/"emode/")[0].selectedIndex =" . ($this->error_mode - 1) . "</script>";
        if(is_array($arr)){
            $len = count($arr);
            for($i = 0; $i < $len; $i++){
                $this->is_valid($arr[$i]);
            }
        }

        if($this->error_no > 1)    
            $this->display_error();
    }

    function is_valid($str){
        $str = split(",", $str);
        if(count($str) < 3) return false;
        $name = trim($str[0]);
        $message = trim($str[1]);
        $data_type = trim($str[2]);
        $value = trim($_POST[$name]);

        switch($data_type){
            case "compare" :
                break;
            case "range" :
                break;
            case "repeat" :
                break;
            default :
                $method = "is_".$data_type;
                if(!$this->$method($value))
                    $this->add_error($name, $message);
                break;
        }
    }

    function add_error($name, $message){
        $this->error_item .= "," . $name;
        $this->error_message .= "," . $this->error_no . ":" . $message;
        $this->error_no ++;
    }

    function display_error(){
        $this->error_item = ereg_replace("^,+", "", $this->error_item);
        $this->error_message = ereg_replace("^,+", "", $this->error_message);

        switch($this->error_mode){
            case 4 :
                $info = "以下原因导致提交失败:/t/t/t/t,";
                echo "<script>alert(/"".join("//n", split(",", $info . $this->error_message))."/")</script>";
                //print >>>end;
                break;
            case 5 :
                echo "输入有错误:<br /><ul><li>" . ereg_replace( "/b/d+:", "",join("</li><li>", split(",", $this->error_message))) . "</li></ul>";
                echo "<br /><a href='javascript:history.back()'>返回</a>";
                exit;
                break;
            default :
                echo "<script defer>dispError(/"" . $this->error_item . "/", /"" . $this->error_message . "/", " . $this->error_mode . ", /",/")</script>";
            break;
        }
    }

    function is_email($str){
        return preg_match("/^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*$/", $str);
    }

    function is_url($str){
        return preg_match("/^http:[A-Za-z0-9]+/.[A-Za-z0-9]+[//=/?%/-&_~`@[/]/':+!]*([^<>/"])*$/", $str);
    }

    function is_qq($str){
        return preg_match("/^[1-9]/d{4,8}$/", $str);
    }

    function is_zip($str){
        return preg_match("/^[1-9]/d{5}$/", $str);
    }

    function is_idcard($str){
        return preg_match("/^/d{15}(/d{2}[A-Za-z0-9])?$/", $str);
    }

    function is_chinese($str){
        return ereg("^[".chr(0xa1)."-".chr(0xff)."]+$",$str);
    }

    function is_english($str){
        return preg_match("/^[A-Za-z]+$/", $str);
    }

    function is_mobile($str){
        return preg_match("/^((/(/d{3}/))|(/d{3}/-))?13/d{9}$/", $str);
    }

    function is_phone($str){
        return preg_match("/^((/(/d{3}/))|(/d{3}/-))?(/(0/d{2,3}/)|0/d{2,3}-)?[1-9]/d{6,7}$/", $str);
    }

    function is_safe($str){
        return (preg_match("/^(([A-Z]*|[a-z]*|/d*|[-_/~!@#/$%/^&/*/./(/)/[/]/{/}<>/?/'/"]*)|.{0,5})$|/s/", $str) != 0);
    }
}
$v = new Validator();
$v->Validate(array("Name,名字只允许中文,chinese", "Nick, 只允许英文昵称, english", "Homepage, 主页Url格式不正确, url", "Password, 密码不符合安全规则, safe","Email,信箱格式错误,email", "QQ, QQ号码不存在, qq","Card, 身份证号码不正确, idcard","Phone, 电话号码不存在, phone","Mobile, 手机号码不存在, mobile","Zip, 邮政编码不存在, zip"));
?>



3、JS版本
HTML代码


[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]


转摘自网上,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值