服务器端数据验证

现在有一个方法实现页面所有textbox的数据验证,
public static bool CheckAllItems(Page page,string strFrmName)
page :传过来的 page
strFrmName: 是页面上面的 Form id
这个方法会检测画面上面所有的 textbox 的验证
这个方法依赖 客户端验证的自定义属性(例如: datatype="string" nullable="no" chname="JobCardNo" ),
然后在调用该方法完成简单的数据效验,具体需要可以自己再完善
例子:
       if(pageCommLibrary.CheckAllItems(this,"Form1")==false)
       {
              return;
       }
把CheckAllItems写在公用cs文件里,在需要的页面直接按上面调用既可,具体代码如下(有好的方法望指教):
public   static   bool      CheckAllItems(Page page, string  strFrmName)
        
{
            
string strDataType="";
            
string strNullable="";
            
string strChname="";
            
string strCheckText="";

            Array array
= Array.CreateInstance(typeof(string), 50);

            
foreach(System.Web.UI.Control Ctr in page.Controls)
            
{
                
if(Ctr.ID==null)
                
{
                    
continue;
                }


                
string ID=Ctr.ID.ToString();

                
if(ID.ToLower()==strFrmName.ToLower())
                
{
                    
foreach(System.Web.UI.Control CtrDet in Ctr.Controls)
                    
{
                        
if(CtrDet is System.Web.UI.WebControls.TextBox)
                        
{
                            System.Web.UI.WebControls.TextBox txtbox
=(System.Web.UI.WebControls.TextBox)CtrDet;
                            strCheckText
=txtbox.Text.Trim();

                            
if(txtbox.ReadOnly==true || txtbox.Enabled==false)
                                
continue;

                            
if(txtbox.Attributes.Keys.Count<50 && txtbox.Attributes.Keys.Count>0)
                            
{

                                txtbox.Attributes.Keys.CopyTo(array,
0);

                                
for(int i=0;i<txtbox.Attributes.Keys.Count;i++)
                                
{
                                    
string strAttItem=array.GetValue(i).ToString();
                                    
if(strAttItem.ToLower().Trim()=="datatype")
                                    
{
                                        strDataType
=txtbox.Attributes[strAttItem].Trim();
                                    }

                                    
if(strAttItem.ToLower().Trim()=="nullable")
                                    
{
                                        strNullable
=txtbox.Attributes[strAttItem].Trim();
                                    }

                                    
if(strAttItem.ToLower().Trim()=="chname")
                                    
{
                                        strChname
=txtbox.Attributes[strAttItem].Trim();
                                    }

                                }


                                
if(strNullable.Trim().ToLower()=="no")
                                
{
                                    
if(strCheckText=="")
                                    
{
                                        
//alert "not allowed null"
                                        pageCommLibrary.showJSMsgInPage(page,strChname+" don't allowed null!!");
                                        
return false;
                                    }

                                }


                                
if(txtbox.MaxLength!=0)
                                
{
                                    
if(CheckStrLen(page,strChname,strCheckText,txtbox.MaxLength)==false)
                                    
{
                                        
//alert "too long"  CheckStrLen
                                        return false;
                                    }

                                }


                                
if(strNullable.Trim().ToLower()=="no")
                                
{
                                    
if(strDataType.Trim().ToLower()=="int")
                                    
{
                                        
//alert "int"
                                        if(CheckDataType(page,strChname,strCheckText,typeof(int))==false)
                                        
{
                                            
return false;
                                        }

                                    }

                                    
else if(strDataType.Trim().ToLower()=="decimal")
                                    
{
                                        
//alert "decimal"
                                        if(CheckDataType(page,strChname,strCheckText,typeof(decimal))==false)
                                        
{
                                            
return false;
                                        }


                                    }

                                    
else if(strDataType.Trim().ToLower()=="datetime")
                                    
{
                                        
//alert "decimal"
                                        if(CheckDataType(page,strChname,strCheckText,typeof(DateTime))==false)
                                        
{
                                            
return false;
                                        }

                                    }

                                }

                                
else //if(strNullable.Trim().ToLower()=="yes")
                                {
                                    
if(strCheckText!="")
                                    
{
                                        
if(strDataType.Trim().ToLower()=="int")
                                        
{
                                            
//alert "int"
                                            if(CheckDataType(page,strChname,strCheckText,typeof(int))==false)
                                            
{
                                                
return false;
                                            }

                                        }

                                        
else if(strDataType.Trim().ToLower()=="decimal")
                                        
{
                                            
//alert "decimal"
                                            if(CheckDataType(page,strChname,strCheckText,typeof(decimal))==false)
                                            
{
                                                
return false;
                                            }


                                        }

                                        
else if(strDataType.Trim().ToLower()=="datetime")
                                        
{
                                            
//alert "decimal"
                                            if(CheckDataType(page,strChname,strCheckText,typeof(DateTime))==false)
                                            
{
                                                
return false;
                                            }

                                        }

                                    }

                                }

                            }

                            
else
                            
...
                        }

                    }

                }

            }

            
return true;
        }
常用的服务器端数据验证控件 RequiredFieldValidator(必须项); CompareValidator(与某值的比较); RangeValidator(范围检查); RegularExpressionValidator(模式匹配); CustomValidator(用户定义); ValidationSummary控件用于在网页、消息框或在这两者中内联显示所有验证错误的摘要 RequiredFieldValidator控件默认检查非空字符串(空格不算在内)。在RequiredFieldValidator关联的表单字段中输入任何字符,该RequiredFieldValidator控件就不会显示它的验证错误信息。 RequiredFieldValidator控件用于要求用户在提交表单前为表单字段输入值。使用Required- FieldValidator控件时,必须设置两个重要的属性: ControlToValidate——被验证的表单字段的ID。 Text——验证失败时显示的错误信息。 RangeValidator控件用于检测表单字段的值是否在指定的最小值和最大值之间。使用这个控件时,必须设置5个属性: ControlToValidate——被验证的表单字段的ID。 Text——验证失败时显示的错误信息。 MinimumValue——验证范围的最小值。 MaximumValue——验证范围的最大值。 Type——所执行的比较类型。可能的值有String、Integer、Double、Date和Currency。 CompareValidator控件可用于执行三种不同类型的验证任务。可使用CompareValidator执行数据类型检测。换句话说,可以用它确定用户是否在表单字段中输入了类型正确的值,比如在生日数据字段输入一个日期。 也可以用CompareValidator控件在输入表单字段的值和一个固定值之间进行比较。例如,要建立一个拍卖网站,就可以用CompareValidator检查新的起价是否大于前面的起价。 最后,可以用CompareValidator控件比较一个表单字段的值与另一个表单字段的值。例如,可以使用CompareValidator控件检查输入的会议开始日期值是否小于输入的会议结束日期值。 CompareValidator控件有6个重要的属性: ControlToValidate——被验证的表单字段的ID。 Text——验证失败时显示的错误信息。 Type——比较的数据类型。可能的值有String、Integer、Double、Date和Currency。 Operator——所执行的比较的类型。可能的值有DataTypeCheck、Equal、GreaterThan、Greater- ThanEqual、LessThan、LessThanEqual和NotEqual。 ValueToCompare——所比较的固定值。 ControlToCompare——所比较的控件的ID。 RegularExpressionValidator控件用于把表单字段的值和正则表达式进行比较。正则表达式可用于表示字符串模式,比如电子邮件地址、社会保障号、电话号码、日期、货币数和产品编码。 这个控件ValidationExpression中可以输入正则表达式来控制用户输入的字符,正则表达式的用处很多。具体可以在网上自己找一些常用的正则表达式看一下 只能输入数字:"^[0-9]*$"。   只能输入n位的数字:"^\d{n}$"。   只能输入至少n位的数字:"^\d{n,}$"。 。。。。。。。。。。。。。。。。。。。。。。。。。。。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值