從本篇開始作者從 ASP 內建對象著手,為大家詳細剖析 ASP 的六個內建對象和各種組件的特性和方法。
在正式開始學習 ASP 的內建對象和組件之前,先讓我們來認識一些基本概念,這將對各位今後的學習大有幫助。請看下表 :
Active Server 隨 Windows NT 交付的服務器方技術的集合。這些 技術為組件應用程序管理、數據庫訪問、事務和消息 提供一致的服務器方組件、腳本模型和一套集成的系 統服務。 Active Server Pages (ASP) 在服務器上運行 ActiveX 腳本和 ActiveX 組件的服 務器方腳本環境。開發人員可以將腳本和組件結合在 一起創建基於 Web 的應用程序。 ActiveX 允許開發人員為 World Wide Web 創建交互式組件的 內涵豐富的Microsoft 技術術語。允許用不同語言編寫的軟 件組件在網絡環境中一起工作的一組不依賴語言的 互操作技術。ActiveX 的關鍵元素是組件對象模型 (COM) 和 分布組件對象模型 (DCOM)。這些技術已得到開放組織的 許可,已移植到許多平台上。 ADO Active 數據對象。為基於 Internet 以數據為中心的 應用程序而優化的一組基於對象的數據訪問接口。ADO 基於已發布的規范並且隨帶在Microsoft Internet Information Server 和 Microsoft Visual InterDev 中。 DSN 數據源名稱。開放式數據庫接口 (ODBC)用於引 用訪問數據所需的驅動程序或其他信息的邏輯名稱。Internet信 息服務器用於連接到 ODBC 數據源(如 SQL Server 數據庫)的 名稱。 event: 事件 由用戶或 ActiveX 控件產生的程序響應的任何 操作。一般事件包括按鍵盤鍵、通過使用鼠標單擊選 擇按鈕和其他鼠標操作。編程人員編寫響應這些操作 的代碼。 object: 對象 在面向對象編程中,由當作完整實體的操作 和數據組成的變量。對象是基於特定模型的,在對象 中客戶使用對象的服務通過由一組方法或相關函數 的接口訪問對象的數據。然後客戶端可以調用這些方 法執行某中操作。 ODBC 開放式數據庫接口。允許應用程序從各種跨 平台數據訪問的已有數據源標准規格中訪問數據的 應用程序編程接口。 SQL 結構化查詢語言 Structured Query Language。定義和訪 問關系型數據庫的國際標准。
什麼是對象?它可不是指你戀愛的男伴或女伴。在面向對象編程中,對象就是指由當作完整實體的操作和數據組成的變量。對象是基於特定模型的,在對象中客戶使用對象的服務通過由一組方法或相關函數的接口訪問對象的數據,然後客戶端可以調用這些方法執行某中操作。ActiveX 組件是建立 Web 應用程序的關鍵,組件提供了在腳本中執行任務的對象。ActiveX 組件是一個文件,該文件包含執行某項或一組任務的代碼,由於組件可以執行公用任務,這樣程序員們就不必自己去創建執行這些任務的代碼。可以利用組件作為腳本和基於 Web 應用程序的基本構造塊。只要知道如何訪問組件提供的對象,即使是位編寫腳本的新手,也可以在不了解組件運作方式的情況下編寫腳本。總之,組件使您不用學習編程就能夠編寫強大的腳本。組件是包含在動態鏈接庫 .dll 或可執行文件 .exe 中的可執行代碼。組件可以提供一個或多個對象以及對象的方法和屬性。要使用組件提供的對象,請創建對象的實例並將這個新的實例分配變量名。使用 ASP 的 Server.CreateObject 方法可以創建對象的實例,使用腳本語言的變量分配指令可以為對象實例命名。如下例:
Set db=Server.CreateObject("ADODB.Connection")
這裡的變量 db 就是 ASP 程序創建的訪問數據庫的對象實例。
Active Server Pages 提供了可在腳本中使用的內建對象。這些對象使用戶更容易收集通過浏覽器請求發送的信息、響應浏覽器以及存儲用戶信息 , 從而使對象開發者擺脫了很多煩瑣的工作。目前的 ASP 版本總共提供了六個內建對象,下面讓我們將通過實例分別來進行學習。
一、Request 對象
可以使用 Request 對象訪問任何基於 HTTP 請求傳遞的所有信息,包括從 HTML 表格用 POST 方法或 GET 方法傳遞的參數、cookie 和用戶認證。Request 對象使您能夠訪問客戶端發送給服務器的二進制數據。
Request 的語法 :
Request[. 集合 | 屬性 | 方法 ]( 變量 )
在這裡作者將挑選一些常用的對象語法進行分析
1、Form
Form 集合通過使用 POST 方法的表格檢索郵送到 HTTP 請求正文中的表格元素的值。
語法
Request.Form(element)[(index)|.Count]
參數
element 指定集合要檢索的表格元素的名稱。
index 可選參數,使用該參數可以訪問某參數中多個值中的一個。它可以是 1 到 Request.Form(parameter).Count 之間的任意整數。
Count 集合中元素的個數
Form 集合按請求正文中參數的名稱來索引。Request.Form(element) 的值是請求正文中所有 element 值的數組。通過調用 Request.Form(element).Count 來確定參數中值的個數。如果參數未關聯多個值,則計數為 1。如果找不到參數,計數為 0。要引用有多個值的表格元素中的單個值,必須指定 index 值。index 參數可以是從 1 到 Request.Form(element).Count 中的任意數字。如果引用多個表格參數中的一個,而未指定 index 值,返回的數據將是以逗號分隔的字符串。
可以使用重述符來顯示表格請求中的所有數據值。例如,用戶通過指定幾個值填寫表格,見下圖。
對於 hobby 參數,您可以使用下面的腳本檢索這些值。
< html>
< head>< title>< /title>< /head> < body>
< p> 請填寫你的愛好 < /p>
< form method="POST" action="form.asp">
< p>< input type="text" name="hobby" size="20">< br>
< input type="checkbox" name="hobby" value=" 足球 "> 足球 < input type="checkbox" name="hobby" value=" 乒乓球 "> 乒乓球 < /p>
< p>< input type="submit" value=" 發送 " name="B1">< input type="reset" value=" 重填 " name="B2">< /p>
< /form>
< % For Each i In Request.Form("hobby") Response.Write i & "< BR>" Next %>
< /body>< /html>
將以上代碼剪貼到記事簿中(注意將“< ”後面的空格去掉),保存為 form.asp 文件並運行,request 對象可以根據你在 form 中填入或選擇元素內容的不同將元素逐個顯示出來。
當然使用 For...Next 循環也可以生成同樣的輸出,如下所示 :
< %
For i = 1 To Request.Form("hobby").Count<
Response.Write Request.Form("hobby")(i) & "< BR>"Next<
%>
2、QueryString
QueryString 集合檢索 HTTP 查詢字符串中變量的值 ,HTTP 查詢字符串由問號 (?) 後的值指定。如:
< A HREF= "example.asp?string=this is a sample">string sample< /A>
生成值為 "this is a sample" 的變量名字符串。通過發送表格或由用戶在其浏覽器的地址框中鍵入查詢也可以生成查詢字符串。
語法
Request.QueryString(variable)[(index)|.Count]
QueryString 集合可以讓您以名稱檢索 QUERY_STRING 變量。Request.QueryString( 參數 ) 的值是出現在 QUERY_STRING 中所有參數的值的數組。通過調用Request.QueryString(parameter).Count 可以確定參數有多少個值。
我們也可以使用 QueryString 來達到與前一個范例相同的功能。只需要將 request.form 部分替換如下:
< %
For Each i In Request.querystring("hobby")
Response.Write i & "< BR>"
Next
%>
3、Cookies
什麼是 Cookie?Cookie 其實是一個標簽,當你訪問一個需要唯一標識你的站址的 WEB 站點時,它會在你的硬盤上留下一個標記,下一次你訪問同一個站