相關(guān)軟件 >把HTML表單提交的數(shù)據(jù)轉(zhuǎn)化成XML文件 創(chuàng)建者:webmaster 更新時間:2005-06-08 23:58 通常,在asp中進(jìn)行的form表單提交的數(shù)據(jù)都被寫進(jìn)數(shù)據(jù)庫管理系統(tǒng)中去,如果你想要你的數(shù)據(jù)是方便攜帶的數(shù)據(jù),你可以把它寫進(jìn)一個XML文件中去。這種方法是跨平臺的,因此你所收集的信息不需要進(jìn)行轉(zhuǎn)換。 為了實(shí)現(xiàn)上面的想法,你必須先利用Microsoft XMLDOM建立一個XML文件,Microsoft XMLDOM對象有一個擴(kuò)展對象庫,它可以創(chuàng)建組成XML文件所需要的元素、屬性、屬性值。 當(dāng)XMLDOM對象實(shí)例化以后,必須對各個元素進(jìn)行引用來建立XML的結(jié)構(gòu),下面的例子就是先建立根元素,并把她追加到XML文件中;然后創(chuàng)建各個子元素,并追加元素的屬性值。最后保存為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" %>
然后編寫ASP代碼,遍歷表單元素,并把輸入的信息寫進(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對象. Set objDom = server.CreateObject("Microsoft.XMLDOM") objDom.preserveWhiteSpace = True
'創(chuàng)建XML文檔的根元素contact,并追加到XML文檔中。 Set objRoot = objDom.createElement("通訊錄") objDom.appendChild objRoot
'遍歷Request對象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")
'釋放所有對象所引用的值 Set objDom = Nothing Set objRoot = Nothing Set objField = Nothing Set objFieldValue = Nothing Set objattID = Nothing Set objattTabOrder = Nothing Set objPI = Nothing End Function