執行個體演練ASP+XML編程
本文是一篇執行個體講解的文章。作為一個普通的程式員,我深知,一個優秀的常式,對於正在學習編程的人是多麼的有協助。本文中使用的常式,是一個聯絡資訊管理程式,我也是寫來以方便自己和朋友們互相聯絡用的。但麻雀雖小,五髒俱全,相信對正在學習ASP+XML編程的朋友們,還是具備一定的參考價值的。
讀者可以通過此執行個體,瞭解在ASP(Active Server Page)中如何操縱XML檔案,並進行資料的各種處理,包括XML節點的建立、修改、刪除和儲存等等。文中涉及到的技術包括ASP,VBScript,DOM,XML和XSL等。
本文未對使用到的技術進行深入的理論介紹,因此,讀者需要具備一定的相關知識,尤其是對ASP、XML和DOM應該有一定的瞭解。通讀本文,並參考原始碼,相信讀者一定可以熟練地掌握XML編程。
一、程式說明
常式基於B/S結構,使用XML檔案儲存體聯絡資訊,然後通過一個VBScript寫的Class,使用DOM,對XML檔案中的聯絡資訊進行各種操作。
常式提供的代碼採用了統一的命名規範,主要包括:用三個字母的縮寫說明變數類型,如數字類型——int,字串類型——str,對象——obj,等等,雖然在ASP/VBScript中,不區分資料類型,但使用明顯的資料類型說明,對程式的編寫和維護還是很有意義的;使用有意義的變數名稱,如XMLDocument對象,定義為objXmlDoc,等等,同樣,這樣做的也是為了更好地編寫和維護程式。
此程式可以分為後台資料處理和前台介面表現兩部分。
程式後台,使用VBScript編寫了一個Class,這是在VBScript5.0版中提供的新特性。雖然這裡Class的概念和真正的物件導向相去甚遠,但是,在ASP中合理地使用Class,還是可以在一定程度上提高程式的運行效率和可維護性。
前台表現,使用XSL對XML檔案中的資料進行了格式化,然後以HTML的形式輸出到用戶端,充分體現了XML技術帶來的靈活性與可定製性。格式化的過程放在了伺服器端,使用ASP程式完成,這樣,用戶端得到的是經過格式化之後的HTML資訊,避免了相容性問題的出現。
當然,程式對於具體的操作細節未作非常嚴格的檢驗,比如聯絡資訊必填項的檢查,但是,對於在ASP中使用DOM操作XML的有關部分,程式提供了完整的範例程式碼。
二、XML檔案說明(persons.xml)
常式中使用到的XML檔案結構十分簡單,並且沒有定義相關的Schema或者DTD,因為,對於此程式這是不必要的。當然,如果讀者願意自己定義一個的話,也不會對程式的運行產生影響。
程式的資料結構定義如下,Persons集合,它包含多個Person對象,每一個Person對象包括姓名Name、英文名Nick、手機Mobile、電話Tel、電子郵件Email、騰訊QQ和所在公司Company的屬性。將以上定義對應到XML檔案即,Persons為根節點,Person為Persons的子節點,Name、Nick、Mobile、Tel、Email、QQ和Company為Person的子節點。
這樣,我們得到的XML檔案內容如下:
<?xml version="1.0" encoding="gb2312"?>
<Persons>
<Person>
<Name>小東</Name>
<Nick>gwd</Nick>
<Mobile>139XXXXXXXX</Mobile>
<Tel>XXXXXXXX</Tel>
<Email>gwd@chinaren.com</Email>
<QQ>7066015</QQ>
<Company>XXX</Company>
<Person>
</Person>
讀者需要注意<?xml version="1.0" encoding="gb2312"?>這一行,XML預設不支援中文,通過設定encoding屬性,才可以使XML正確地顯示中文。讀者可以在IE5.0及以上版本的瀏覽器中訪問此檔案,它會以 樹型結構把資料顯示出來。
轉自:動態網製作指南www.knowsky.com
轉自:動態網製作指南www.knowsky.com
三、格式轉換XSL檔案說明(Persons.xsl)
常式中使用XSL對XMl資料進行格式化,並以HTML的形式返回到用戶端。這個過程也可以放在用戶端進行,但考慮到相容性的問題,常式中採用了在伺服器端通過ASP操縱DOM進行格式化的方法。
XSL檔案的內容如下,
<?xml version="1.0" encoding="gb2312"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:template match="/Persons">
<script language="javascript">
function add()
{
window.open("add.asp", "add", "width=300,height=320,resize=no");
}
function edit(intId)
{
window.open("edit.asp?id="+intId, "edit", "width=300,height=320,resize=no");
}
</script>
<table width="600" border="0" align="center">
<tr>
<td align="right"><a href="javascript:add();" title="添加新連絡人">添加新連絡人</a> </td>
</tr>
</table>
<table align="center" width="680" cellspacing="1" cellpadding="2" border="0" bgcolor="#666600">
<tr class="title" bgcolor="#E5E5E5">
<td width="25"><xsl:text disable-output-escaping="yes">&</xsl:text>nbsp;</td>
<td>姓名</td>
<td>英文名</td>
<td>手機</td>
<td>電話</td>
<td>Email</td>
<td>QQ</td>
<td>所在公司</td>
</tr>
<xsl:for-each select="Person">
<TR BGCOLOR="#FFFFFF">
<TD ALIGN="right"><xsl:value-of select="position()"/></TD>
<TD STYLE="color:#990000"><A><xsl:attribute name="HREF">javascript:edit('<xsl:value-of select="position()"/>');</xsl:attribute><xsl:attribute name="title">修改資訊 </xsl:attribute><xsl:value-of select="Name"/></A></TD>
<TD><xsl:value-of select="Nick"/></TD>
<TD><xsl:value-of select="Mobile"/></TD>
<TD><xsl:value-of select="Tel"/></TD>
<TD><A><xsl:attribute name="HREF">mailto:<xsl:value-of select="Email"/></xsl:attribute><xsl:value-of select="Email"/></A></TD>
<TD><xsl:value-of select="QQ"/></TD>
<TD><xsl:value-of select="Company"/></TD>
</TR>
</xsl:for-each>
</table>
</xsl:template>
</xsl:stylesheet>
在伺服器端的轉換使用一個函數來完成,格式化成功,返回HTML字串,格式化失敗,列印出錯誤資訊,如下,
'*******************************************
' 說明:使用XSL檔案格式化XML檔案。
' 作者:gwd 2002-11-05
' 參數:strXmlFile -- Xml檔案,路徑+檔案名稱
' strXslFile -- Xsl檔案,路徑+檔案名稱
' 返回:成功 -- 格式化後的HTML字串
' 失敗 -- 自訂的錯誤資訊
'*******************************************
Function FormatXml(strXmlFile, strXslFile)
Dim objXml, objXsl
strXmlFile = Server.MapPath(strXmlFile)
strXslFile = Server.MapPath(strXslFile)
Set objXml = Server.CreateObject("MSXML2.DOMDocument")
Set objXsl = Server.CreateObject("MSXML2.DOMDocument")
objXML.Async = False
If objXml.Load(strXmlFile) Then
objXsl.Async = False
objXsl.ValidateonParse = False
If objXsl.Load(strXslFile) Then
On Error Resume Next ' 捕獲transformNode方法的錯誤
FormatXml = objXml.transformNode(objXsl)
If objXsl.parseError.errorCode <> 0 Then
Response.Write "<br><hr>"
Response.Write "Error Code: " & objXsl.parseError.errorCode
Response.Write "<br>Error Reason: " & objXsl.parseError.reason
Response.Write "<br>Error Line: " & objXsl.parseError.line
FormatXml = "<span class=""alert"">格式化XML檔案錯誤!</span>"
End If
Else
Response.Write "<br><hr>"
Response.Write "Error Code: " & objXsl.parseError.errorCode
Response.Write "<br>Error Reason: " & objXsl.parseError.reason
Response.Write "<br>Error Line: " & objXsl.parseError.line
FormatXml = "<span class=""alert"">裝載XSL檔案錯誤!</span>"
End If
Else
Response.Write "<br><hr>"
Response.Write "Error Code: " & objXml.parseError.errorCode
Response.Write "<br>Error Reason: " & objXml.parseError.reason
Response.Write "<br>Error Line: " & objXml.parseError.line
FormatXml = "<span class=""alert"">裝載XML檔案錯誤!</span>"
End If
Set objXsl = Nothing
Set objXml = Nothing
End Function
當前1/3頁
123下一頁閱讀全文