一些常用ASP ActiveX 組件使用方法的介紹
這篇文章將給大家介紹一些常用ASP ActiveX 組件使用方法,希望能幫助到大家。
當(dāng)你用 ASP 編寫服務(wù)器端應(yīng)用程序時(shí),必須依靠 ActiveX 組件來強(qiáng)大 Web 應(yīng)用程序的功能,譬如:你需要連接數(shù)據(jù)庫,對(duì)數(shù)據(jù)庫進(jìn)行在線操作等等,
最近仍有不少朋友來信問我, ASP 是否只能在 Microsoft IIS 上運(yùn)行,是否可以在非 NT 平臺(tái)上運(yùn)作?本來這個(gè)問題我已經(jīng)回答過很多遍了 : 我只是聽說過有某種可以支持的軟件,卻從沒見過。但一些熱情的朋友仍然孜孜不倦地來信詢問,于是在朋友們的盛情之下,我訪遍了 ASP 相關(guān)站點(diǎn),竟驚奇的發(fā)現(xiàn),原來 ASP 的確是可以運(yùn)行在其它非 NT 平臺(tái)上的,因此在本篇的開頭,我就給來信的朋友們簡(jiǎn)要介紹一下如何在非 NT 平臺(tái)上使用 ASP。
要在非 NT 平臺(tái)上開發(fā)并運(yùn)行 ASP 應(yīng)用程序我們可以依賴于一套名為 Instant ASP 的第三方軟件,它的廣告標(biāo)語非常吸引人“ASP Anytime, Anywhere”,我想所有 ASP 的開發(fā)者們看到如此的標(biāo)語必然興奮不已。這套由 Halcyon 軟件公司開發(fā)的軟件使得你無需重復(fù)開發(fā)原有 ASP 應(yīng)用程序即可以將它運(yùn)行在任何操作平臺(tái)上 ! 這樣非但節(jié)省了大量的開發(fā)時(shí)間,而且使得 ASP 真正成為了一種跨平臺(tái)的 Internet、 Intranet 或 Extranet 應(yīng)用程序。 Instant ASP 本身其實(shí)是一套基于 Java 的應(yīng)用程序,因此通過它你可以將基于 WEB 的 ASP 應(yīng)用程序運(yùn)行在任何平臺(tái)上,下表列出了 Instant ASP 目前版本所支持的操作平臺(tái)。
更令人吃驚的是 Instant ASP 不僅提供了 ASP 的運(yùn)作環(huán)境,而且它較目前市場(chǎng)上的 ASP 應(yīng)用還提供了更為強(qiáng)大和實(shí)用的功能,它將 ActiveX 組件和 EntERPrise Java Beans 或者 CORBA-compliant objects 組合起來,從而使 ASP 有了更為廣泛的應(yīng)用。它同樣提供了通過 ADO 接口訪問連接各種數(shù)據(jù)庫,并生成動(dòng)態(tài)頁面的強(qiáng)大功能。對(duì)于開發(fā)者而言可以使用自己擅長(zhǎng)的編程語言或工具如 :Visual Basic, JScript, VBScript, C++, Java, HTML, Delphi , MS Visual InterDev 等等來進(jìn)行開發(fā)。關(guān)于 Instant ASP 具體安裝和操作我就不在這里展開了,有興趣的朋友可以到它的站點(diǎn)上去看看 halcyonsoft.com,你還可以免費(fèi)下載一個(gè)試用版試試。
今天我們接著來看看其它的一些 ASP 常用組件。
一、 Database Access 組件
我們?cè)?WEB 服務(wù)器上運(yùn)用 WEB 應(yīng)用程序進(jìn)行的最常見和最實(shí)用的任務(wù)就是訪問服務(wù)器端的數(shù)據(jù)庫。而 ASP 內(nèi)建的 Database Access 組件使得我們能夠輕而易舉地通過 ActiveX Data Objects (ADO) 訪問存儲(chǔ)在服務(wù)器端的數(shù)據(jù)庫或其他表格化數(shù)據(jù)結(jié)構(gòu)中的信息。 ADO 是對(duì)當(dāng)前微軟所支持的數(shù)據(jù)庫進(jìn)行操作的最有效和最簡(jiǎn)單直接的方法,它是一種功能強(qiáng)大的數(shù)據(jù)訪問編程模式,從而使得大部分?jǐn)?shù)據(jù)源可編程的屬性得以直接擴(kuò)展到你的 Active Server 頁面上?梢允褂 ADO 去編寫緊湊簡(jiǎn)明的腳本以便連接到 Open Database Connectivity (ODBC) 兼容的數(shù)據(jù)庫和 OLE DB 兼容的數(shù)據(jù)源,這樣 ASP 程序員就可以訪問任何與 ODBC 兼容的數(shù)據(jù)庫,包括 MS SQL SERVER、 Access、 Oracle 等等。如果您是一個(gè)對(duì)數(shù)據(jù)庫連接有一定了解的腳本編寫人員,那么您將發(fā)現(xiàn) ADO 命令語句并不復(fù)雜而且容易掌握。同樣地,如果您是一個(gè)經(jīng)驗(yàn)豐富的數(shù)據(jù)庫編程人員,您將會(huì)正確認(rèn)識(shí) ADO 的先進(jìn)的與語言無關(guān)性和查詢處理功能。熟悉 VB 數(shù)據(jù)庫編程的朋友會(huì)發(fā)現(xiàn) ADO 與 RDO (Remote Data Objects) 有某種類似的地方。但據(jù)說 ADO 的訪問的速度更快,內(nèi)存需要更小。
下面給大家簡(jiǎn)要介紹一下利用 ASP 的 Database Access 組件通過 ADO 連接并操作 WEB 數(shù)據(jù)庫的步驟
第一步 : 指定想要連接的數(shù)據(jù)庫,有 DSN 和 DSN-less 兩種方法。
DSN(Data Source Name 數(shù)據(jù)源名稱 ): 建立一個(gè)系統(tǒng)數(shù)據(jù)源名稱,方法如下 :
1、單擊“開始”,選設(shè)置控制面板。
2、雙擊圖標(biāo)“32 位 ODBC” , 將彈出一個(gè)對(duì)話框,選標(biāo)簽“System DSN”
3、單擊“Add”添加一個(gè) DSN 入口 , 選擇如“Microsoft Access Drive”并確認(rèn)。
4、在“Data Source Name”欄里輸入你希望指定的 DSN, 然后單擊“Select”選擇數(shù)據(jù)庫存放位置,你可以按“Browse”來選取。
5、以上步驟完成后在 ASP 程序中指定 DSN,如下 :
< % connstr = "DSN"%>
DSN-less: 是另一種通過在 ASP 文件里直接指定數(shù)據(jù)庫文件所在位置,而無需建立 DSN 的方法。由于許多公司沒有自己的 WEB 服務(wù)器,他們的網(wǎng)站往往是存放在遠(yuǎn)端的虛擬服務(wù)器上,因此要建立和修改 DSN 的設(shè)置比較麻煩。而使用 DSN-less 方法直接指定遠(yuǎn)端數(shù)據(jù)庫所在位置恰恰解決了這一問題,方法如下 :
< % connstr = "DSN"%>
DSN-less: 是另一種通過在 ASP 文件里直接指定數(shù)據(jù)庫文件所在位置,而無需建立 DSN 的方法。由于許多公司沒有自己的 WEB 服務(wù)器,他們的網(wǎng)站往往是存放在遠(yuǎn)端的虛擬服務(wù)器上,因此要建立和修改 DSN 的設(shè)置比較麻煩。而使用 DSN-less 方法直接指定遠(yuǎn)端數(shù)據(jù)庫所在位置恰恰解決了這一問題,方法如下 :
<%
connstr="DBQ="+server.mappath("database/source.mdb")+";DefaultDir=;DRIVER={Microsoft Access Driver (*.mdb)};"
%>
在指定了想要連接的數(shù)據(jù)庫后,就可以通過以下方法連接并打開數(shù)據(jù)庫 :
< %
Set Conn = Server.CreateObject("ADODB.Connection")
Conn.Open constr
%>
第二步 : 指定想要執(zhí)行的 SQL 指令,可以使用 RecordSet。
當(dāng)連接了數(shù)據(jù)庫后就可以對(duì)數(shù)據(jù)庫進(jìn)行操作,比如查詢、刪除、更新等等,這些操作都是通過 SQL 指令來完成的,如下例在數(shù)據(jù)庫表 datebase 中查詢所有姓名中有“A”的記錄 :
< %
sql="select * from datebase where name like "A%%""
Set rs = Conn.Execute(sql)
%>
盡管 Connection 對(duì)象簡(jiǎn)化了連接數(shù)據(jù)庫和查詢?nèi)蝿?wù),但 Connection 對(duì)象仍有許多不足。確切地說,檢索和顯示數(shù)據(jù)庫信息的 Connection 對(duì)象不能用于創(chuàng)建腳本,您必須確切知道要對(duì)數(shù)據(jù)庫作出的更改,然后才能使用查詢實(shí)現(xiàn)更改。對(duì)于檢索數(shù)據(jù)、檢查結(jié)果、更改數(shù)據(jù)庫, ADO 提供了 Recordset 對(duì)象。正如它的名稱所暗示的那樣, Recordset 對(duì)象有許多您可以使用的特性,根據(jù)您的查詢限制,檢索并且顯示一組數(shù)據(jù)庫行,即記錄。 Recordset 對(duì)象保持查詢返回的記錄的位置,允許您一次一項(xiàng)逐步掃描結(jié)果。根據(jù) Recordset 對(duì)象的指針類型屬性設(shè)置,您可以滾動(dòng)和更新記錄。數(shù)據(jù)庫指針可以讓您在一組記錄中定位到特定的項(xiàng)。指針還用于檢索和檢查記錄,然后在這些記錄的基礎(chǔ)上執(zhí)行操作。 Recordset 對(duì)象有一些屬性,可用于精確地控制指針的行為,提高您檢查和更新結(jié)果的能力。
Recordset 的使用方法如下 :
Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open SQL 指令 , Conn, 1, 1 " 讀取
或
rs.Open SQL 指令 , Conn, 1, 3 " 新增、修改、或刪除
第三步 : 使用 RecordSet 屬性和方法,并顯示執(zhí)行的結(jié)果。
通過以上指令,我們創(chuàng)建了一個(gè)包含數(shù)據(jù)的游標(biāo) (RecordSet)“rs”,事實(shí)上游標(biāo)是存儲(chǔ)在活動(dòng)內(nèi)存中的類似記錄和字段的數(shù)組的東西,當(dāng)通過 RecordSet 組件創(chuàng)建一個(gè)游標(biāo)時(shí),它從數(shù)據(jù)提供者的得到一個(gè)數(shù)據(jù)集,并用它來充實(shí)游標(biāo),我們可以想象 ADO 產(chǎn)生的 RecordSet 是一個(gè)象電子表格的記錄,它有一行行的記錄,在任何時(shí)候都有一行是它的當(dāng)前行,而 RecordSet 的字段是用 RecordSet 的 Field 集合表示的。下面列出了所創(chuàng)建的 RecordSet 對(duì)象 ( 游標(biāo) ) 的一些屬性和方法 :
rs.Fields.Count: RecordSet 對(duì)象的字段總數(shù)。
rs(i).Name: 第 i 個(gè)字段的名稱, i 由 0 算起到 rs.Fields.Count-1。
rs(i): 讀取第 i 個(gè)字段的數(shù)據(jù), i 由 0 算起到 rs.Fields.Count-1。
rs(" 字段名稱 "): 讀取指定字段的數(shù)據(jù)。
rs.RecordCount: 游標(biāo)中的數(shù)據(jù)記錄總數(shù)。
rs.EOF: 是否已指到最后一條記錄。
rs.MoveNext: 將指標(biāo)移到下一筆記錄。
rs.MovePrev: 將指標(biāo)移到上一筆記錄。
rs.MoveFirst: 將指標(biāo)移到第一筆記錄。
rs.MoveLast: 將指標(biāo)移到最后一筆記錄。
rs.Close: 關(guān)閉 RecordSet 對(duì)象