您当前的位置:论文发表网论文中心计算机类计算机应用
 子栏目导航
电子商务
计算机应用
计算机理论
计算机网络
 最新推荐
· 毕业论文写作的基本要求...
· 轰响新机制的黄钟——论...
· 叙事差异与价值取向——...
· 中国电视主持人职业生涯...
· 创办国家级电视新闻频道...
· 信息的重复和缺失——对...
· 境外电视频道落地广东的...
· 传媒话语生产与控制
· 试论一种特殊的传播方式...
· 浅析知识经济时代图书编...
· 广告中女性形象的思考
· “传媒外交”初探
 热门文章
  • 毕业论文写作的基本要求...
  • 轰响新机制的黄钟——论...
  • 论中外合作经营企业先行...
  • 我国保险业应对WT0的思考...
  • WTO背景下中国广播电视业...
  • MAS-2型微机自动准同期装...
  • 陈寅恪“守老僧之旧义”...
  • 固体废弃物的焚烧对生物...
  • 武警学院地热供热站房设...
  • PLC控制系统与智能化中央...
  •  相关文章
    · asp 3.0高级编程(一...
    · asp 3.0高级编程(二...
    · asp 3.0高级编程(三...
    · asp 3.0高级编程(四...
     
    asp 3.0高级编程(二)

    减小字体 增大字体

    使用form和querystring集合
    当用户填写页面<form>内容时所提供的全部值,或在浏览器地址栏输入在url后的值,通过form和querystring集合为asp脚本所用。这是在asp代码中访问值的一种简单方法。
    1、 访问asp集合的一般技术
    大多数asp集合与在vb中见到的普通集合相差不多。实际上,它们是值的数组,但能通过使用一个文本字符串键(对大小不敏感)以及一个整型索引进行访问。因此,假如客户端web页面包含的<form>如下:
    <form action=”show_request.asp” method=”post”>
    firstname:<input type=”text” name=”firstname”>
    lastname:<input type=”text” name=”lastname”>
    <input type=”submit” value=”send”>
    </form>
    可通过访问asp的form集合来访问其控件内的值:
    strfirstname = request.form(“firstname”)
    strlastname = request.form(“lastname”)
    也可使用窗体中控件的整型索引,索引的范围从在html中第一个定义的控件开始,然后根据定义的顺序排序:
    strfirstname = request.form(1)
    strlastname = request.form(2)
    然而,后面的这种以整型为索引的技术不推荐使用,因为一旦有html中的控件发生了变化,或者插入一个新的控件,则asp代码将得到错误的值。进一步而言,对于阅读代码的人来讲,极容易混淆。
    1) 访问集合的全部值
    可以通过引用集合把整个form上的一系列值变成单个的字符变量,且不用提供键或索引。
    strallformcontent = request.form
    假如文本框包含值priscilla和descartes,则request.form语句将返回下列字符:
    firstname=priscilla&lastname=descartes
    注意,提供的值是以名称/值对的形式出现的(即控件名称=控件值),并且每一对名称/值相互之间是用符号“&”相分隔的。假如打算把窗体中的内容传递单独的,希望得到值的标准格式的可执行应用程序或dll,这个技术是很有用的。然而,一般说来,都是通过以窗体中控件的名称为文本键来访问集合中的内容。
    2) 遍历一个asp集合
    有两种方式遍历一个asp集合中的所有成员,方式与普通vb集合的基本相同。每个集合提供一个count属性,返回的是集合中条目数量。可通过使用一个整型索引使用count属性来遍历。
    for intloop=1 to request.form.count
    response.write request.form(intloop) & “<br>”
    next
    假如先前的窗体包含priscilla和descartes值的两个文本框,将得到如下结果:
    priscilla
    descartes
    然而,更好的方法是使用for each...next结构。
    for each objitem in request.form
    response.write objitem & “=” & request.form(objitem) & “<br>”
    next
    这带来的好处是既可以访问控件的名称又可访问其值。上述代码将得到如下结果:
    firstname = priscilla
    lastname = descartes
    注意,一些浏览器返回到asp的<form>值可能与页面上显示的顺序不尽相同。
    3) 集合成员的多值性
    在某些情况下,asp集合中的各个成员可能不止一个值,这种情况发生在html定义中有几个控件有相同name属性时。例如:
    <form action=”show_request.asp” method=”post”>
    <input type=”text” name=”otherhobby”>
    <input type=”text” name=”otherhobby”>
    <input type=”text” name=”otherhobby”>
    <input type=”submit” value=”send”>
    </form>
    在form集合中,将为“otherhobby”创建一个条目。然而,它将包括从三个文本框中得到的值。假如在提交时,用户留下了一个或多个为空,则返回的值为空字符串。假如用户在第一和第三个文本框分别输入gardening和mountaineering,第二个文本框为空,在我们的asp代码中访问request.form(“otherhobby”),将返回字符串:
    gardening, ,mountaineering
    为了能够在这种情况下,访问单个值,可以用复杂一些的代码:
    for each objitem in request.form
    if request.form(objitem).count >1 then ‘more than one value in this item
    response.write objitem & “:<br>”
    for intloop = 1 to request.form(objitem).count
    response.write “subkey” & intloop & “value = “_
    & request.form(objitem) (intloop) & “<br>”
    next
    else
    response.write objitem & “ = ” & request.form(objitem) & “<br>”
    end if
    next
    对于前面的包含三个otherhobby控件的窗体实例,这将返回:
    otherhobby:
    subkey 1 value = gardening
    subkey 2 value = 
    subkey 3 value = mountaineering
    然而,由于很少给多个文本框相同的名字,因此这种技术很少用到。
    a) html中的单选或选页按钮控件
    在html中,需要给几个控件相同的name属性的情况是单选(或选项)按钮,例如:
    <form action=”show_request.asp” method=”post”>
    i live in:
    <input type=”radio” name=”country” value=”am”>america<br>
    <input type=”radio” name=”country” value=”eu”>europe<br>
    <input type=”radio” name=”country” value=”as”>asia<br>
    <input type=”submit” value=”send”>
    </form>
    因为用户只能选择多项中的一个(这就是给它们相同的名字的原因),将仅得到一个返回值,浏览器只能发送所选择控件的值。因此,假如这个窗体的用户已经选择了“europez”,将得到这个条目,通过遍历form集得到其值:
    country = eu
    由于为每个控件提供了不同的value属性,反映了每个条目所对应的国家或地区的名称。假如省略了value属性,浏览器将返回的值为“on”,因此将得到:
    country = on
    这是不经常用到的,因此一般对使用相同名称的单选控件使用value属性。
    b) html复选框控件
    当一个窗体中html源码包含一个复选框控件时,一般都给定唯一的名称,例如:
    <form action=”show_request.asp” method=”post”>
    i enjoy:
    <input type=”checkbox” name=”reading” checked> reading 
    <input type=”checkbox” name=”eating”> eating 
    <input type=”checkbox” name=”sleeping”> sleeping
    <input type=”submit” value=”send”>
    </form>
    在这种情况下,提交窗体时,假如仅是第一和第三个复选框被选中(加标记),遍历form集合时,会得到下列值:
    reading = on
    sleeping = on
    然而,假如为每个复选框提供一个值,把这个值发往服务器代替字符串“on”。例如窗体如下:
    <form action=”show_request.asp” method=”post”>
    i enjoy:
    <input type=”checkbox” value=”hobby025” name=”hobby” checked>_
    swimming 
    <input type=”checkbox” value=”hobby003” name=”hobby” checked>_
    reading 
    <input type=”checkbox” value=”hobby068” name=”hobby”>eating 
    <input type=”checkbox” value=”hobby010” name=”hobby”>sleeping
    <input type=”submit” value=”send”>
    </form>
    如果除第三个复选框外,全部提交,在request.form集合会产生下列结果:
    hobby = hobby025, hobby003, hobby010
    假如编写更复杂一些集合遍历代码,如先前所述(单独显示每个子键),就得到这样结果:
    hobby:
    subkey 1 value = hobby025
    subkey 2 value = hobby003
    subkey 3 value = hobby010
    需要注意的是两种情况,没有选中的控件根本不返回任何值。在第一种情况的结果里,没有欺骗性的逗号,第二种情况也没有空值。这与上述的使用文本框的相当的测试的结果不一样。使用文本框时,每个文本框都返回一个值,即使是一个空字符串。这是浏览器造成这样的结果。因此在asp代码中访问集合时,要注意这个问题。
    上述情况一个棘手的负作用是使用复选框时,复选框值的索引与在原始的html中控件的位置没有任何联系,在上述的例子中第四个复选框的子键数为3,因为当窗体提交时,第二个控件没有选中。
    c) html列表控件
    html中的<select>标记用来产生标准的下拉列表框,其值以一种有趣的混合方式表示。下列的窗体创建了包含5个值可供用户选择,由于包含了multiple属性,因此可以通过选择时按下shift或ctrl键,选择不仅一个的条目。
    <form action=”show_request.asp” method=”post”>
    <select name=”hobby” size=”5” multiple>
    <option value=”hobby001”>programming</option>
    <option value=”hobby025”>swimming</option>
    <option value=”hobby003”>reading</option>
    <option value=”hobby068”>eating</option>
    <option value=”hobby010”>sleeping</option>
    </select><p>
    <input type=”submit” value=”send”>
    </form>
    下图所示为该页面,显示的是选中了三个条目。

    这种特殊的情况返回的是在form集合中单个条目,它包含选择的值(单个的<option>标记中指定的value属性),用逗号分隔:
    hobby = hobby025, hobby003, hobby010
    假如使用更加复杂一些的集合遍历代码(单独显示每个子键),将得到:
    hobby:
    subkey 1 value = hobby025
    subkey 2 value = hobby003
    subkey 3 value = hobby010
    这与上述相同名称的复选框的情况相同。事实上可以认为一个select列表是一列复选框的列表供选择(不是选中)相应的条目。
    然而,列表框也有指定的值,假如在<option>标记中设置value属性,将得到的是选择的选项的文本内容,request.form集将包含这样一个项目:
    hobby = swimming, reading, sleeping
    并且,同样,复杂一些的集合遍历代码将返回如下结果:
    hobby:
    subkey 1 value = swimming
    subkey 2 value = reading
    subkey 3 value = sleeping
    当然,假如单个项目被选择,且在<option>中提供了value属性,得到结果包含的仅是:
    hobby = hobby025
    如果没有提供value属性,得到:
    hobby = swimming
    这允许既可以缺省(即无value)显示选项文本,也可做相应的改变。后一种情况在某些情况下是极为有用的,如要显示(一个说明的字符串)和传递一个完全不同的内容(如用一个短码代表一个说明性的字符串)。
    d) html提交和图像控件
    复选框和单选框是布尔型控件的例子,选中或选择返回的为“on”,不像文本框和大多数其他的html控件,浏览器不包含没有选中或没有选择的控件的值。
    还有另外一种常用的布尔型控件,称为html按钮。如<input type=”submit”>、<input type=”reset”>、<input type=”image”>、<input type=”button”>和<button>...</button>类型。
    button类型的控件不返回任何值,因其对窗体没有直接的影响。即使使用用来调用窗体的submit方法,浏览器在任何请求中将不包含button类型控件的值。同样,一个<input type=”reset”>按钮的值也决不会发往服务器。
    然而,输入按钮控件submit和image类型实际提交窗体给服务器,其value属性包含窗体的其他控件的值(只要在html定义中包含一个name属性)。例如,这个窗体可能是向导类型web应用程序的一部分,允许用户一步步进行或取消进程:
    <form action=”show_request.asp” method=”post”>
    <input type=”submit” name=”btnsubmit” value=”next”>
    <input type=”submit” name=”btnsubmit” value=”previous”>
    <input type=”subimt” name=”btnsubmit” value=”cancel”>
    </form>
    在一个窗体中,可以包括多个submit按钮。在这种情况下,应该给每一个按钮唯一的value属性,如上所示。当一个窗体被提交时,遍历request.form集合的值,将产生一个值,这个值依赖于按下哪个按钮用于提交这个窗体。假如用户按下的“previous”按钮,将得到:
    btnsubmit = previous
    因此,可查询request.form集合来决定下一个显示的页面,例如:
    select case request.form(“btnsubmit”)
    case “next”
    response.redirect “page_3.asp”
    case “previous”
    response.redirect “page_1.asp”
    case “cancel”
    response.redirect “main_menu.asp”
    end select
    同时,也可根据需要对每个按钮使用不同的name属性。且选择其值包含在form集合中的控件名称。在控件没有一个完整的标记而是随后跟着较长的文本标签的情况下,极为有用,如下图所示。

    此屏幕上的界面由下列代码产生:
    <form action=”show_request.asp” method=”post”>
    <b>what do you want to do now?</b><p>
    <input type=”submit” name=”btnnext” value= ”> go on the next page<p>
    <input type=”submit” name=”btnprevious” value=” ”> go back to the previous page<p>
    <input type=”submit” name=”btncancel” value=” ”> cancel and go back to the main menu page<p>
    </form>
    在asp页面中,接收到数据后,可以检查按扭名称提供的值来判断按下的是哪个按钮。
    if len(request.form(“btnnext”)) then response.redirect “page_3.asp”
    if len(request.form(“btnprevious”)) then response.redirect “page_1.asp”
    if len(request.form(“btncancel”)) then response.redirect “main_menu.asp”
    这个工作是查询一个键上的asp集合,如果不存在则返回一个空的字符串。换句话说,如果第二个按钮(previous页)按下,则request.form(“btnnext”)的值是一个空字符串,则其长度为零而不至于产生一个错误。当第二个按钮按下时,则在form集合中这个条目的值request.form(“btnprevious”),将是“ ”其长度大于零。
    e) 提高使用request集合的效率
    访问一个asp集合来下载一个值是费时的需计算资源的过程,因为这个操作包含了一系列对相关集合的搜索,这比访问一个局部变量要慢得多。因此,如果打算在页面中多次使用集合中的一个值,应该考虑将其存贮成为一个局部变量,例如:
    strtitle = request.form(“title”)
    strfirstname = request.form(“firstname”)
    strlastname = request.form(“lastname”)
    if len(sttitle) then strtitle = strtitle & “ “
    if strfirstname = “ “ then
    strfullname = strtitle & “ “ & strlastname
    elseif len(strfirstname) = 1 then
    strfullname = strtitle & strfirstname & “· “ & strlastname
    else
    strfullname = strtitle & strfirstname & “ ” & strlastname
    end if
    f) 搜索所有的request集合
    在某些情况下,可能知道一个值的键名将出现在request集合中,但不能准确地知道是哪一个集合。例如,假如有几个页面(或一个页面的不同段)发送一个值给同一个asp脚本,它可能在form或者querystring集合中出现。
    本章后面部分将研究form和querystring集合的差异。
    要看一下一个值为什么可能出现在不同的集合中,考虑一下这种情况:使用了<a>超级链接元素请求一个页面。在这种情况下,增加一个值到请求的唯一方法是把它加到url上。然而,同样的值可能已出现在另一个页面的<form>中,或同一页面不同部分:
    ...
    <form action=”process_page.asp” method=”post”>
    <input type=”submit” name=”page” value=”next”>
    <input type=”submit” name=”page” value=”previous”>
    <input type=”submit” name=”page” value=”help”>
    </form>
    ...
    ...
    for help go to the <a href=”process_page.asp?page=help”>help page</a>
    ...
    在这种情况下,按下窗体上的help按钮,将发送request.form集合中一对名称/值“page=help”。然而,按下<a>超级链接也可能发送名称/值“page=help”,但是这次却是在querystring集合里。为访问这个值,可使用asp request对象的一个特殊功能:
    strpage = request(“page”)
    这将按序搜索全部的集合——querystring、form、cookies、clientcertificate、servervariables,直到发现第一个匹配值的名称。这样做比直接访问适当的集合效率低,并且是不安全的,除非能绝对保证这个值不会出现在另外一个集合中。
    例如,可能希望搜集满足客户请求的web服务器的名称,这通过出现在每个查询中的request.servervariables集合中寻找“server_name”来实现。然而,假如任一其他的集合也包含名为“server_name”的值(记住键名不区分大小写),当使用request(“server_name”)时,得到的是错误的结果。使用reqeust.servervariables(“server_name”)句法,我们将很难进行错误追踪。
    总而言之,使用“搜索全部集合”技术要格外小心,且只在没有其他技术能够提供你需要的结果时使用。
    g) 访问其他的集合
    本章的这一节里,已经集中讨论了form集合,这可能是使用得最多的一个。然而,所有这些技术同样适用于其他的对象。包括那些由request对象提供的(即form、querystring、cookies、servervariables和clientcertificate)集合,及由response对象提供的cookies(及将在下两章遇到的其他对象提供的集合)。
    我们将简短了解一个值如何进入一个querystring集合,及其优点和不足。然而,同时这两个cookies集合有额外的功能,可以使使用cookie更加方便,下面讨论这个内容。

    [] [返回上一页] [打 印] [收 藏]
    上一篇论文中心:asp 3.0高级编程(三)
    下一篇论文中心:asp 3.0高级编程(一)