ASP.NETWeb服务器验证控件如何使用

 更新时间:2022年04月26日 09:47:41   投稿:lijiao  
这篇文章主要介绍了ASP.NETWeb服务器验证控件如何使用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

脚本之家 / 编程助手:解决程序员“几乎”所有问题!
脚本之家官方知识库 → 点击立即使用

什么是验证控件?

希望用户输入正确的类型的数据,为了验证用户输入是否满足要求,必须对输入的值、范围或格式进行检查。

.NET中验证控件在哪里?

在工具箱的验证分组里。

常用的ASP.NET控件几个?分别是什么?

1)CompareValidator控件:与给定值比较.
2)CustomValidator控件:用户自己定制校验逻辑
3)RangeValidator控件:检查控件的值是否在给定的有效范围内。
 4)RegularExpressValidator控件:使用正则表达式验证用户输入的数据是否符合预定义的格式。
5)RequiredFieldValidator控件:防止用户输入空值。
6)ValidationSummary控件:汇总Web页上所有验证控件的错误信息。

追本溯源:

所有的验证控件都是从基类BaseValidator中继承而来的,为验证控件提供了一些公有的属性:

 

怎样使用ASP.Net验证控件?

和添加其他服务器控件一样,即可启用对用户输入的验证。
在控件的ControlToValidator属性中赋予要关联验证控件的ID号,关联起来。

客户端验证?服务器验证?                

                    

客户端的验证

为了用户体验,防止人家提交很多遍都填不对 例如一些合法性检查,比如字符串长度,非法字符,正则表达式,非空等。大多是友好提示(本质不靠谱,但响应快。)
服务器端的验证

业务逻辑、安全性需要的真正的验证,比如密码对不对,需要在后台写代码来有没有权限之类的。需要提交数据并保存的地方,放到服务器验证。(为了安全,客户端验证的,服务器端也验证。)

混合验证:

客户端和服务器都需要验证啦。

DEMO:

这里面主要说说客户端验证和服务器验证 两种方式,以CustomValidator控件为例:
验证用户输入的是否为偶数

客户端验证:

在这里用到JavaScrip代码:

1
2
3
4
5
6
7
8
9
10
<script language="javascript " type="text/javascript">
  /*验证是否为偶数函数*/
    function ClientValidate(source, args) 
    {
      if ((args.value % 2) == 0)
          args.IsValid = true;
      else
          args.IsValid = false;
    }
</script>

客户端验证控件代码:

1
2
<asp:CustomValidator ID="CustomValidator1" runat="server" 
    ControlToValidate="txtOS" ErrorMessage="不是一个偶数!" ClientValidationFunction="ClientValidate"></asp:CustomValidator>

服务器验证,C#代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public partial class _Default : System.Web.UI.Page
{
  //服务器端验证输入是否为偶数。
  protected void cvInput_ServerValidate(object source, ServerValidateEventArgs args)
  {
    //获取验证控件输入值。
    int value = int.Parse(args.Value);
    //判断是否为偶数。
    if ((value % 2) == 0)
    {
      args.IsValid = true;
    }
    else
    {
      args.IsValid = false;
    }
  }
}

服务器验证,控件代码:                      

1
2
<asp:CustomValidator ID="cvInput" runat="server" 
      ControlToValidate="txtOS" ErrorMessage="不是一个偶数!" OnServerValidate="ServerValidate" ></asp:CustomValidator>

最终得到的效果图如下所示:

        

和CS的控件比起来,CS的控件中没有验证控件哦。

学了母版、用户控件的使用,今天又学习了ASP.NETWeb服务器验证控件的使用方法,希望大家每篇文章都有所收获。

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

相关文章

最新评论