用ASP、VB與XML創(chuàng)建互聯(lián)網(wǎng)應(yīng)用程序(2)
發(fā)表時間:2024-02-21 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]讓我們先分析一下客戶端/服務(wù)器應(yīng)用程序。在一個標(biāo)準(zhǔn)的客戶端/服務(wù)器應(yīng)用程序中,在應(yīng)用程序開始時,你能夠初始化數(shù)據(jù)庫連接字符串,這就意味著,客戶有使用數(shù)據(jù)庫連接字符串的權(quán)利,這包括用戶名和口令。但是客觀情況如果不允許你在網(wǎng)絡(luò)上發(fā)送這些信息的話,你就必需在不聯(lián)接數(shù)據(jù)庫的情況下直接從客戶端取得數(shù)據(jù)發(fā)送給...
讓我們先分析一下客戶端/服務(wù)器應(yīng)用程序。在一個標(biāo)準(zhǔn)的客戶端/服務(wù)器應(yīng)用程序中,在應(yīng)用程序開始時,你能夠初始化數(shù)據(jù)庫連接字符串,這就意味著,客戶有使用數(shù)據(jù)庫連接字符串的權(quán)利,這包括用戶名和口令。但是客觀情況如果不允許你在網(wǎng)絡(luò)上發(fā)送這些信息的話,你就必需在不聯(lián)接數(shù)據(jù)庫的情況下直接從客戶端取得數(shù)據(jù)發(fā)送給客戶。那么解決方案之一就是在服務(wù)器上創(chuàng)建一個ASP頁(在本例中稱為getData.asp)接收特定格式的POST數(shù)據(jù),它要求一個包含XML字符串,用來創(chuàng)建ADO對象并運行存儲過程或動態(tài)SQL語句命令。如果信息有效的話,getData.asp執(zhí)行存儲過程,并返回一個XML格式的數(shù)據(jù)集、返回值列表或錯誤頁面信息的XML字符串。對于返回數(shù)據(jù)的命令,客戶端要么重新實例化要么返回值或使用XML DOM(Document Object Model文檔對象模型)格式的錯誤頁面。
好,下面就讓我們來討論一下如何實現(xiàn)這個頁面吧!
getData.asp頁面首先使用一個DOMDocument對象來保存客戶端發(fā)送的數(shù)據(jù):
'創(chuàng)建DOMDocument對象
Set xml = Server.CreateObject ("msxml2.DOMDocument")
xml.async = False
然后,它裝載POST數(shù)據(jù)
'裝載POST數(shù)據(jù)
xml.Load Request
If xml.parseError.errorCode <> 0 Then
Call responseError ("不能裝載XML信息。" & "Description: " & xml.parseError.reason & "<br>Line: " & xml.parseError.Line)
End If
它能夠返回commandtext元素值和returndata或returnvalue元素值。下面我只給出返回commandtext元素值的代碼,其余代碼請參看我下面所附的源程序。
Set N = xml.selectSingleNode("command/commandtext")
If N Is Nothing Then
Call responseError ("缺少 <sp_name> 參數(shù)。")
Else sp_name = N.Text
End If
接著,應(yīng)該讓頁面創(chuàng)建一個Command對象,讀入所有<param>元素,并且為request中的每一個元素創(chuàng)建一個參數(shù)。最后,讓頁面打開一個連接使用存儲過程adExecuteNoRecords選項來執(zhí)行request。
set conn = Server.CreateObject("ADODB.Connection")
conn.Mode=adModeReadWrite
conn.open Application("ConnectionString")
set cm.ActiveConnection=conn
' 返回數(shù)據(jù)
if not returnsData then
cm.Execute
else
set R = server.CreateObject("ADODB.Recordset")
R.CursorLocation = adUseClient
R.Open cm, ,adOpenStatic, adLockReadOnly
end if
如果能夠返回數(shù)據(jù)的話,那么returnData變量就為真值,并且把結(jié)果數(shù)據(jù)集返回到客戶端,仍然是一個XML文檔。
if returnsData then
R.Save Response, adPersistXML
if err.number <> 0 then
call responseError ("數(shù)據(jù)集發(fā)生存儲錯誤" & "在命令'" & CommandText & "': " & Err.Description)
Response.end
end if
如果輸出參數(shù)返回值,那么這個頁面將返回一個包含這些值的XML字符串。文檔的根元素是一個<values>標(biāo)記,每一個返回值都有其相應(yīng)的子元素,如果發(fā)生任何錯誤,頁面都會格式化并返回一個包含錯誤信息的XML字符串:
Sub responseError(sDescription)
Response.Write "<response><data>錯誤: " & sDescription & "</data></response>"
Response.end
End Sub