通常,在ASP中進(jìn)行的form表單提交的數(shù)據(jù)都被寫(xiě)進(jìn)數(shù)據(jù)庫(kù)中,如果你想要你的數(shù)據(jù)是便于遷移的數(shù)據(jù),你可以把它寫(xiě)進(jìn)一個(gè)XML文件中。這種方法是跨平臺(tái)的,你所收集的信息不需要進(jìn)行轉(zhuǎn)換就可以轉(zhuǎn)移到其他平臺(tái)進(jìn)行使用。
為了實(shí)現(xiàn)上面的想法,你必須先利用 Microsoft.XMLDOM 建立一個(gè)XML文件,Microsoft.XMLDOM 對(duì)象有一個(gè)擴(kuò)展對(duì)象庫(kù),它可以創(chuàng)建組成XML文件所需要的元素、屬性、屬性值。
當(dāng) XMLDOM對(duì)象實(shí)例化以后,必須對(duì)各個(gè)元素進(jìn)行引用來(lái)建立XML的結(jié)構(gòu),下面的例子就是先建立根元素,并把她追加到XML文件中;然后創(chuàng)建各個(gè)子元素,并追加元素的屬性值。最后保存為XML文件。
實(shí)例化 Microsoft XMLDOM Object:
<%
Dim objDom
Dim objRoot
Dim objChild1
Dim objChild2
Dim objPI
Set objDom = Server.CreateObject("Microsoft.XMLDOM")
Set objRoot = objDom.createElement("rootElement")
objDom.appendChild objRoot
Set objChild1 = objDom.createElement("childElement1")
objRoot.appendChild objChild1
Set objChild2 = objDom.createElement("childElement2")
objRoot.appendChild objChild2
Set objPI = objDom.createProcessingInstruction("xml","version='1.0'")
objDom.insertBefore objPI, objDom.childNodes(0)
objDom.Save "c:\MyXMLDoc.xml"
%>
一旦你保存了文件,用IE5+打開(kāi)后,樣式如下[當(dāng)然,屬性還沒(méi)有被賦值]:
MyXMLDoc.xml:
下面我們來(lái)看看怎樣利用這個(gè)對(duì)象來(lái)存儲(chǔ)用戶的輸入信息。
首先建立輸入表單的頁(yè)面EnterContact.html:
通訊信息
然后編寫(xiě)ASP代碼,遍歷表單元素,并把輸入的信息寫(xiě)進(jìn)XML文件processForm.asp:
<%
'--------------------------------------------------------------------
'函數(shù) "ConvertFormtoXML"接收傳遞的參數(shù)。
'strXMLFilePath - XML存放的物理地址。
'strFileName - 要保存的XML文件的名字。
'--------------------------------------------------------------------
Function ConvertFormtoXML(strXMLFilePath, strFileName)
'定義本地變量.
Dim objDom
Dim objRoot
Dim objField
Dim objFieldValue
Dim objattID
Dim objattTabOrder
Dim objPI
Dim x
'實(shí)例化Microsoft XMLDOM對(duì)象.
Set objDom = server.CreateObject("Microsoft.XMLDOM")
objDom.preserveWhiteSpace = True
'創(chuàng)建XML文檔的根元素contact,并追加到XML文檔中。
Set objRoot = objDom.createElement("通訊錄")
objDom.appendChild objRoot
'遍歷Request對(duì)象Form元素的集合。
For x = 1 To Request.Form.Count
If instr(1,Request.Form.Key(x),"btn") = 0 Then
'創(chuàng)建元素 "field".
Set objField = objDom.createElement("field")
'創(chuàng)建屬性 "id".
Set objattID = objDom.createAttribute("id")
'設(shè)定id屬性的值等于Form中各元素的值。
objattID.Text = Request.Form.Key(x)
'setAttributeNode 方法把id屬性值追加到field元素。
objField.setAttributeNode objattID
'創(chuàng)建屬性taborder。
Set objattTabOrder = objDom.createAttribute("taborder")
'設(shè)定taborder的屬性值
objattTabOrder.Text = x
'把taborder的屬性值追加到field元素中去。
objField.setAttributeNode objattTabOrder
'創(chuàng)建一個(gè)新的元素field_value.
Set objFieldValue = objDom.createElement("field_value")
'賦值
objFieldValue.Text = Request.Form(x)
'追加field元素為根元素的子元素。
objRoot.appendChild objField
'追加field_value做為子元素的內(nèi)容
objField.appendChild objFieldValue
End If
Next
'創(chuàng)建xml聲明
Set objPI = objDom.createProcessingInstruction("xml", "version='1.0' encoding='gb2312'")
'把xml生命追加到xml文檔
objDom.insertBefore objPI, objDom.childNodes(0)
'保存xml文件
objDom.save strXMLFilePath & "\" & strFileName
'釋放所有對(duì)象所引用的值
Set objDom = Nothing
Set objRoot = Nothing
Set objField = Nothing
Set objFieldValue = Nothing
Set objattID = Nothing
Set objattTabOrder = Nothing
Set objPI = Nothing
End Function
'發(fā)生錯(cuò)誤時(shí)繼續(xù)執(zhí)行
On Error Resume Next
'調(diào)用函數(shù)ConvertFormtoXML把文件存放到指定的文件目錄和文件名。
ConvertFormtoXML "D:\aspexam","Contact.xml"
'如果發(fā)生錯(cuò)誤,提示用戶,否則報(bào)告成功。
If err.number <> 0 then
Response.write("保存form值出現(xiàn)錯(cuò)誤?。?!")
Else
Response.write("提交成功??!")
End If
%>
用IE5+打開(kāi)Contact.xml文件。
為了實(shí)現(xiàn)上面的想法,你必須先利用 Microsoft.XMLDOM 建立一個(gè)XML文件,Microsoft.XMLDOM 對(duì)象有一個(gè)擴(kuò)展對(duì)象庫(kù),它可以創(chuàng)建組成XML文件所需要的元素、屬性、屬性值。
當(dāng) XMLDOM對(duì)象實(shí)例化以后,必須對(duì)各個(gè)元素進(jìn)行引用來(lái)建立XML的結(jié)構(gòu),下面的例子就是先建立根元素,并把她追加到XML文件中;然后創(chuàng)建各個(gè)子元素,并追加元素的屬性值。最后保存為XML文件。
實(shí)例化 Microsoft XMLDOM Object:
<%
Dim objDom
Dim objRoot
Dim objChild1
Dim objChild2
Dim objPI
Set objDom = Server.CreateObject("Microsoft.XMLDOM")
Set objRoot = objDom.createElement("rootElement")
objDom.appendChild objRoot
Set objChild1 = objDom.createElement("childElement1")
objRoot.appendChild objChild1
Set objChild2 = objDom.createElement("childElement2")
objRoot.appendChild objChild2
Set objPI = objDom.createProcessingInstruction("xml","version='1.0'")
objDom.insertBefore objPI, objDom.childNodes(0)
objDom.Save "c:\MyXMLDoc.xml"
%>
一旦你保存了文件,用IE5+打開(kāi)后,樣式如下[當(dāng)然,屬性還沒(méi)有被賦值]:
MyXMLDoc.xml:
下面我們來(lái)看看怎樣利用這個(gè)對(duì)象來(lái)存儲(chǔ)用戶的輸入信息。
首先建立輸入表單的頁(yè)面EnterContact.html:
通訊信息
然后編寫(xiě)ASP代碼,遍歷表單元素,并把輸入的信息寫(xiě)進(jìn)XML文件processForm.asp:
<%
'--------------------------------------------------------------------
'函數(shù) "ConvertFormtoXML"接收傳遞的參數(shù)。
'strXMLFilePath - XML存放的物理地址。
'strFileName - 要保存的XML文件的名字。
'--------------------------------------------------------------------
Function ConvertFormtoXML(strXMLFilePath, strFileName)
'定義本地變量.
Dim objDom
Dim objRoot
Dim objField
Dim objFieldValue
Dim objattID
Dim objattTabOrder
Dim objPI
Dim x
'實(shí)例化Microsoft XMLDOM對(duì)象.
Set objDom = server.CreateObject("Microsoft.XMLDOM")
objDom.preserveWhiteSpace = True
'創(chuàng)建XML文檔的根元素contact,并追加到XML文檔中。
Set objRoot = objDom.createElement("通訊錄")
objDom.appendChild objRoot
'遍歷Request對(duì)象Form元素的集合。
For x = 1 To Request.Form.Count
If instr(1,Request.Form.Key(x),"btn") = 0 Then
'創(chuàng)建元素 "field".
Set objField = objDom.createElement("field")
'創(chuàng)建屬性 "id".
Set objattID = objDom.createAttribute("id")
'設(shè)定id屬性的值等于Form中各元素的值。
objattID.Text = Request.Form.Key(x)
'setAttributeNode 方法把id屬性值追加到field元素。
objField.setAttributeNode objattID
'創(chuàng)建屬性taborder。
Set objattTabOrder = objDom.createAttribute("taborder")
'設(shè)定taborder的屬性值
objattTabOrder.Text = x
'把taborder的屬性值追加到field元素中去。
objField.setAttributeNode objattTabOrder
'創(chuàng)建一個(gè)新的元素field_value.
Set objFieldValue = objDom.createElement("field_value")
'賦值
objFieldValue.Text = Request.Form(x)
'追加field元素為根元素的子元素。
objRoot.appendChild objField
'追加field_value做為子元素的內(nèi)容
objField.appendChild objFieldValue
End If
Next
'創(chuàng)建xml聲明
Set objPI = objDom.createProcessingInstruction("xml", "version='1.0' encoding='gb2312'")
'把xml生命追加到xml文檔
objDom.insertBefore objPI, objDom.childNodes(0)
'保存xml文件
objDom.save strXMLFilePath & "\" & strFileName
'釋放所有對(duì)象所引用的值
Set objDom = Nothing
Set objRoot = Nothing
Set objField = Nothing
Set objFieldValue = Nothing
Set objattID = Nothing
Set objattTabOrder = Nothing
Set objPI = Nothing
End Function
'發(fā)生錯(cuò)誤時(shí)繼續(xù)執(zhí)行
On Error Resume Next
'調(diào)用函數(shù)ConvertFormtoXML把文件存放到指定的文件目錄和文件名。
ConvertFormtoXML "D:\aspexam","Contact.xml"
'如果發(fā)生錯(cuò)誤,提示用戶,否則報(bào)告成功。
If err.number <> 0 then
Response.write("保存form值出現(xiàn)錯(cuò)誤?。?!")
Else
Response.write("提交成功??!")
End If
%>
用IE5+打開(kāi)Contact.xml文件。

