从ASP迁移至ASP+--CustomValidator控件

发表于:2007-06-30来源:作者:点击数: 标签:
有了CustomValidator控件,我们可以书写自己的客户端或 服务器 的验证代码,从而进行验证。在这个站点的原始版本中,我们将输入表格中的数据传递给cookie.asp页,在该页执行验证后,若产生错误便传回错误代码。为了简化整个过程,我们打算将数据传回给signup
    
     有了CustomValidator控件,我们可以书写自己的客户端或服务器的验证代码,从而进行验证。在这个站点的原始版本中,我们将输入表格中的数据传递给cookie.asp页,在该页执行验证后,若产生错误便传回错误代码。为了简化整个过程,我们打算将数据传回给signup.aspx页,在那儿执行验证,如果一切ok就进行重定向。这样一来,所有的验证都被集中在一个ASP+页面上了(而在ASP中,只能集中在cookie.asp页上)。
  
     以下示例如何用CustomValidator来检验用户名:
  
     Function ValidateUserName(ByVal objSource As Object, ByVal strUserName As String) As Boolean
  
     Dim dscUser As ADODataSetCommand
  
     Dim dsUser As New DataSet
  
     Dim dvUser As DataView
  
     Dim strSQL As String
  
     strSQL = "SELECT UserName FROM Students " & _
  
     "WHERE UserName = @#" & strUserName & "@#"
  
     dscUser = New ADODataSetCommand(strSQL, Connect.ConnectToDB())
  
     dscUser.FillDataSet(dsUser, "User")
  
     UserGrid.DataSource = dsUser.Tables("User").DefaultView
  
     UserGrid.DataBind()
  
     If UserGrid.Items.Count > 0 Then
  
     ValidateUserName = False
  
     Else
  
     ValidateUserName = True
  
     End If
  
     dvUser = New DataView(dsUser.Tables("User"))
  
     End Function
  
     < /script>
  
     [page stuff...]
  
     < asp:DataGrid id="UserGrid" visible=false runat=server />
  
     < asp:CustomValidator runat=server
  
     ControlToValidate = "txtUserName"
  
     onServerValidationFunction = "ValidateUserName"
  
     errorMessage = "The User Name you chose is taken. Please chose another."
  
     ForeColor = "#CC3300"
  
     display = "dynamic"
  
     />
  
     该控件在表格提交之后,触发ValidateUserName函数。接着使用DataSet对数据库进行查询,看是否存在与用户请求的用户名同名的记录。如果该用户名已被占用,则返回一条记录,否则不返回记录。为了进行检验,我们将结果绑定到一个隐藏的DataGrid(将visible属性设为false),然后检验它的Items集合,以及Count属性。如果Count大于0,则请求的用户名已存在。如果用户名已存在,我们返回一条信息;否则,我们继续处理表格。
  
     请注意这是种迂回的验证方式。实际上有一个DataReader控件是专门针对这种功能设计的。DataReader可以无须绑定数据到DataGrid而进行这种类型的验证。然而在ASP+的Alpha版本中,DataReader存在着一个bug,而且不能正常工作。这个问题在Beta1版中会得到解决。我们使用的迂回方式的代码可以让本站点在基于.NET框架的ASP+下正常运行。
  

原文转自:http://www.ltesting.net