佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > ASP+XML實(shí)例演練編程代碼第1/3頁

ASP+XML實(shí)例演練編程代碼第1/3頁

熱門標(biāo)簽:阿里云 科大訊飛語音識別系統(tǒng) 團(tuán)購網(wǎng)站 銀行業(yè)務(wù) 電子圍欄 Linux服務(wù)器 Mysql連接數(shù)設(shè)置 服務(wù)器配置
實(shí)例演練ASP+XML編程

本文是一篇實(shí)例講解的文章。作為一個(gè)普通的程序員,我深知,一個(gè)優(yōu)秀的例程,對于正在學(xué)習(xí)編程的人是多么的有幫助。本文中使用的例程,是一個(gè)聯(lián)系信息管理程序,我也是寫來以方便自己和朋友們互相聯(lián)系用的。但麻雀雖小,五臟俱全,相信對正在學(xué)習(xí)ASP+XML編程的朋友們,還是具備一定的參考價(jià)值的。 

  讀者可以通過此實(shí)例,了解在ASP(Active Server Page)中如何操縱XML文件,并進(jìn)行數(shù)據(jù)的各種處理,包括XML節(jié)點(diǎn)的建立、修改、刪除和保存等等。文中涉及到的技術(shù)包括ASP,VBScript,DOM,XML和XSL等。 

  本文未對使用到的技術(shù)進(jìn)行深入的理論介紹,因此,讀者需要具備一定的相關(guān)知識,尤其是對ASP、XML和DOM應(yīng)該有一定的了解。通讀本文,并參考源代碼,相信讀者一定可以熟練地掌握XML編程。 
  一、程序說明 

  例程基于B/S結(jié)構(gòu),使用XML文件存儲聯(lián)系信息,然后通過一個(gè)VBScript寫的Class,使用DOM,對XML文件中的聯(lián)系信息進(jìn)行各種操作。 

  例程提供的代碼采用了統(tǒng)一的命名規(guī)范,主要包括:用三個(gè)字母的縮寫說明變量類型,如數(shù)字類型——int,字符串類型——str,對象——obj,等等,雖然在ASP/VBScript中,不區(qū)分?jǐn)?shù)據(jù)類型,但使用明顯的數(shù)據(jù)類型說明,對程序的編寫和維護(hù)還是很有意義的;使用有意義的變量名稱,如XMLDocument對象,定義為objXmlDoc,等等,同樣,這樣做的也是為了更好地編寫和維護(hù)程序。 

  此程序可以分為后臺數(shù)據(jù)處理和前臺界面表現(xiàn)兩部分。 

  程序后臺,使用VBScript編寫了一個(gè)Class,這是在VBScript5.0版中提供的新特性。雖然這里Class的概念和真正的面向?qū)ο笙嗳ド踹h(yuǎn),但是,在ASP中合理地使用Class,還是可以在一定程度上提高程序的運(yùn)行效率和可維護(hù)性。 

  前臺表現(xiàn),使用XSL對XML文件中的數(shù)據(jù)進(jìn)行了格式化,然后以HTML的形式輸出到客戶端,充分體現(xiàn)了XML技術(shù)帶來的靈活性與可定制性。格式化的過程放在了服務(wù)器端,使用ASP程序完成,這樣,客戶端得到的是經(jīng)過格式化之后的HTML信息,避免了兼容性問題的出現(xiàn)。 

  當(dāng)然,程序?qū)τ诰唧w的操作細(xì)節(jié)未作非常嚴(yán)格的檢驗(yàn),比如聯(lián)系信息必填項(xiàng)的檢查,但是,對于在ASP中使用DOM操作XML的有關(guān)部分,程序提供了完整的示例代碼。 
  二、XML文件說明(persons.xml) 

  例程中使用到的XML文件結(jié)構(gòu)十分簡單,并且沒有定義相關(guān)的Schema或者DTD,因?yàn)椋瑢τ诖顺绦蜻@是不必要的。當(dāng)然,如果讀者愿意自己定義一個(gè)的話,也不會對程序的運(yùn)行產(chǎn)生影響。 

  程序的數(shù)據(jù)結(jié)構(gòu)定義如下,Persons集合,它包含多個(gè)Person對象,每一個(gè)Person對象包括姓名Name、英文名Nick、手機(jī)Mobile、電話Tel、電子郵件Email、騰訊QQ和所在公司Company的屬性。將以上定義對應(yīng)到XML文件即,Persons為根節(jié)點(diǎn),Person為Persons的子節(jié)點(diǎn),Name、Nick、Mobile、Tel、Email、QQ和Company為Person的子節(jié)點(diǎn)。 

  這樣,我們得到的XML文件內(nèi)容如下: 
  <?xml version="1.0" encoding="gb2312"?> 
 ?。糚ersons> 
   ?。糚erson> 
      ?。糔ame>小東</Name> 
     ?。糔ick>gwd</Nick> 
     ?。糓obile>139XXXXXXXX</Mobile> 
     ?。糡el>XXXXXXXX</Tel> 
      <Email>gwd@chinaren.com</Email> 
     ?。糛Q>7066015</QQ> 
      <Company>XXX</Company> 
   ?。糚erson> 
  </Person> 
  讀者需要注意<?xml version="1.0" encoding="gb2312"?>這一行,XML默認(rèn)不支持中文,通過設(shè)置encoding屬性,才可以使XML正確地顯示中文。讀者可以在IE5.0及以上版本的瀏覽器中訪問此文件,它會以 樹型結(jié)構(gòu)把數(shù)據(jù)顯示出來。 
轉(zhuǎn)自:動態(tài)網(wǎng)制作指南www.knowsky.com 

轉(zhuǎn)自:動態(tài)網(wǎng)制作指南www.knowsky.com 
  三、格式轉(zhuǎn)換XSL文件說明(Persons.xsl) 

  例程中使用XSL對XMl數(shù)據(jù)進(jìn)行格式化,并以HTML的形式返回到客戶端。這個(gè)過程也可以放在客戶端進(jìn)行,但考慮到兼容性的問題,例程中采用了在服務(wù)器端通過ASP操縱DOM進(jìn)行格式化的方法。 

  XSL文件的內(nèi)容如下, 
<?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"> 
?。紅r> 
 ?。紅d align="right"><a href="javascript:add();" title="添加新聯(lián)系人">添加新聯(lián)系人</a>  </td> 
?。?tr> 
</table> 

<table align="center" width="680" cellspacing="1" cellpadding="2" border="0" bgcolor="#666600"> 
?。紅r class="title" bgcolor="#E5E5E5"> 
 ?。紅d width="25"><xsl:text disable-output-escaping="yes"></xsl:text>nbsp;</td> 
 ?。紅d>姓名</td> 
  <td>英文名</td> 
 ?。紅d>手機(jī)</td> 
 ?。紅d>電話</td> 
 ?。紅d>Email</td> 
 ?。紅d>QQ</td> 
 ?。紅d>所在公司</td> 
 </tr> 
?。紉sl:for-each select="Person"> 
?。糡R BGCOLOR="#FFFFFF"> 
 ?。糡D ALIGN="right"><xsl:value-of select="position()"/></TD> 
 ?。糡D 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> 
 ?。糡D><xsl:value-of select="Mobile"/></TD> 
 ?。糡D><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> 
 ?。糡D><xsl:value-of select="QQ"/></TD> 
 ?。糡D><xsl:value-of select="Company"/></TD> 
 </TR> 
?。?xsl:for-each> 
</table> 
</xsl:template> 
</xsl:stylesheet> 
  在服務(wù)器端的轉(zhuǎn)換使用一個(gè)函數(shù)來完成,格式化成功,返回HTML字符串,格式化失敗,打印出錯(cuò)誤信息,如下, 
'******************************************* 
' 說明:使用XSL文件格式化XML文件。 
' 作者:gwd 2002-11-05 
' 參數(shù):strXmlFile -- Xml文件,路徑+文件名 
' strXslFile -- Xsl文件,路徑+文件名 
' 返回:成功 -- 格式化后的HTML字符串 
' 失敗 -- 自定義的錯(cuò)誤信息 
'******************************************* 
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方法的錯(cuò)誤 
   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文件錯(cuò)誤?。?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文件錯(cuò)誤?。?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文件錯(cuò)誤?。?span>" 
 End If 
 Set objXsl = Nothing 
 Set objXml = Nothing 
End Function 
123下一頁閱讀全文

標(biāo)簽:大理 蚌埠 棗莊 衡水 江蘇 廣元 衢州 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP+XML實(shí)例演練編程代碼第1/3頁》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    荆州市| 太原市| 柞水县| 鄯善县| 浦东新区| 双辽市| 惠州市| 织金县| 广元市| 奇台县| 休宁县| 广东省| 小金县| 太白县| 扶绥县| 湟中县| 邮箱| 沙雅县| 巴林右旗| 玉屏| 青州市| 娄烦县| 河池市| 邵阳县| 文安县| 长寿区| 南乐县| 象州县| 萨迦县| 吕梁市| 海伦市| 津市市| 固始县| 呼伦贝尔市| 乌拉特前旗| 嘉定区| 商城县| 临清市| 扬中市| 彰化县| 六安市|