使用 ASP Request 对象,您可以创建一个简单而功能强大的脚本来收集和处理 HTML 表单数据。在本主题中,您将不仅学会如何创建基本的表单处理脚本,而且还将获得用于验证 Web 服务器和用户浏览器上的表单信息的一些有用技术。
关于 HTML 表单
HTML 表单是收集 Web 信息最常用的方法,是在 Web 页上提供用户界面控件的特殊的 HTML 标记的排列。文本框、按钮和复选框都是典型的控件,这些控件使用户和 Web 页实现交互,并且将信息提交给 Web 服务器。
下面的 HTML 示例产生一个表单,在表单中,用户可以输入姓名、年龄并包含一个将这些信息提交给 Web 服务器的按钮。该表单也包含了一个隐含的控件(Web 浏览器不显示),可以用该控件向 Web 浏览器传递附加信息。
<FORM METHOD="POST" ACTION="myfile.asp"> <INPUT TYPE="text" NAME="firstname"> <INPUT TYPE="text" NAME="lastname"> <INPUT TYPE="text" NAME="age"> <INPUT TYPE="hidden" NAME="userstatus" VALUE= "new"> <INPUT TYPE="submit" VALUE="Enter"> </FORM>
处理 ASP 输入的表单
在表单向 Web 服务器提交信息时,用户的 Web 浏览器请求用 HTML <FORM > 标记的 ACTION 属性所指定的 .asp 文件。.asp 文件包含了处理表单值(如显示结果表或从数据库查询信息)的脚本。
可以通过三种途径用 .asp 文件收集 HTML 表单的值
- 静态的 .htm 文件可以包含一个将其数值传送给.asp 文件的表单。
- .asp 文件可以创建一个将其信息传送给另一个 .asp 文件的表单。
- .asp 文件可以创建一个将其信息传送给自身的表单,即包含该表单的文件。
前两个方法的操作方式相同,当表单与网关程序交互时,除 ASP 之外,可以包含读取和响应用户选择的命令。
获得表单输入
ASP的Request对象提供了两种集合,在很大程度上简化了检索附加在 URL 请求上的表单信息的任务。
QueryString 集合
QueryString 集合获取作为跟在请求的 URL 的问号后面的文本传递给 Web 服务器的值。通过使用 HTTP的 GET 方法或手工将表单的值添加到 URL,表单的值可以被附加在请求的 URL 之后。
例如,如果先前的表单示例使用 GET 方法 (METHOD = "GET") 且用户键入 Jeff、Smith 和 30,那么下面的 URL 请求将被发送给服务器:
xx.asp?firstname=Jeff&lastname=Smith&age=30&userstatus=new
xx.asp 包含下面的表单处理脚本:
Hello <%= Request.QueryString("firstname") %> <%= Request.QueryString("lastname") %>. You are <%= Request.QueryString("age") %> years old. <%If Request.QueryString("userstatus") = "new user" then Response.Write"This is your first visit to this Web site!" End if %>
在这种情况下,Web 服务器将返回下面的文本给用户的 Web 浏览器:
QueryString 集合有一个可选参数,可用来访问显示在请求正文中的多个值中的一个。也可以使用 Count 属性计算一个特殊类型的值的出现次数。
例如,表单包含一个多项目的列表框可以提交下面的请求:
list.asp?food=apples&food=olives&food=bread
您也可以使用下面的命令去对多个值计数:
Request.QueryString("food").Count
如果想显示多个值的类型,List.asp 应包含下面的脚本;
<%Total = Request.QueryString("food").Count%> <%For i = 1 to Total%> <%= Request.QueryString("food")(i) %> <BR> <%Next%>
上述脚本将显示:
Form 集合
当使用 HTTP GET 方法去向 Web 服务器传递长而复杂的表单值时,将可能丢失信息。大多数的 Web 服务器倾向于严格控制 URL 查询字符串的长度,以便用 GET 方法传送的冗长的表单值被截断。如果您需要从表单发送大量信息到 Web 服务器,就必须使用 HTTP POST 方法。此法用于在 HTTP 请求正文中发送表单数据,而且发送的字符的个数可以无限多。也可以使用 ASP Request 对象的 Form 集合检索用 POST 方法发送的值。
Form 集合与 QueryString 集合存储数值的方式相同。例如,如果用户用一长串名称填充表单,您就可以用下面的脚本检索这些名称:
<% For i = 1 to Request.Form.Count %> <% =Request.Form("names")(i) %> <% Next %>
验证表单输入
一个好的表单处理脚本在处理数据前,应先验证输入表单的信息是否有效。验证脚本可以检验用户输入到表单的信息类型是否正确。例如,如果您的 Web站点包含一个表单,该表单允许用户计算财务信息,那么在处理结果之前,需要验证用户确实输入了数值信息而不是文本。
一个非常方便的验证表单输入的方法是创建一个向自身传递信息的表单。在这种情况下,.asp文件包含可获取信息的表单。例如,下面的脚本通过向自身传递信息来验证用户是否在 "age" 表单字段中输入了数值:
<% If Isnumeric(Request.QueryString("Age")) then %> Hello, your age is <%=Request.QueryString("age")%> <%Else %> Please enter a numerical age. <%End If %> <FORM METHOD= "POST" ACTION="verify.asp" > Name: <INPUT TYPE="text" NAME="Name" > Age: <INPUT TYPE="text" NAME="Age" > <INPUT TYPE="submit" VALUE="Enter"> </FORM>
在这个例子中,脚本也在包含表单的同一 Verify.asp 文件中。表单通过在 ACTION 属性中指定 Verify.asp 向自身传送信息。
您也可以创建客户端脚本来检验用户是否输入了有效的信息。验证用户在 Web 浏览器上的输入除了更迅速地向用户提示表单项错误外,还可以减少 Web 服务器的网络流量。下面的脚本运行在用户的 Web 浏览器上,在将信息提交到 Web 服务器之前,验证用户信息。
<SCRIPT LANGUAGE="VBScript"> Sub btnEnter_OnClick Dim TheForm Set TheForm = Document.MyForm If IsNumeric(TheForm.Age.Value) Then TheForm.submit Else Msgbox "Please enter a numerical age." End if End Sub </SCRIPT> <FORM METHOD= "POST" NAME= MyForm ACTION="myfile.asp" > Name: <INPUT TYPE="text" NAME="Name" > Age: <INPUT TYPE="text" NAME="Age" > <INPUT TYPE="button" NAME="btnEnter" VALUE="Enter"> </FORM>