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服务器验证控件的使用方法,希望大家每篇文章都有所收获。
微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
相关文章
IIS故障(Connections_Refused)问题分析及处理
这几天某地市Web服务器连续多次出现故障问题(Connections_Refused),正好借这个案例向大家详细介绍下,需要了解的朋友可以参考下2012-12-12
最新评论