TML已經這樣流行了,為什麼還要發展XML?
簡單地講,HTML不能完成,我們希望XML所要完成的任務。原因很簡單,XML所要完成的任務,必須由元置標語言來完成,而HTML只是一個實例置標語言。 在XML發布之前,國際互聯網的發展受到Html如下幾個問題的束縛:
1) Html無法描述數據內容,而這一點恰恰是數據檢索、電子商務所必須的。
2) HTML對數據表現的描述能力是十分不夠的,如Html還不能描述矢量圖形、 科學符號等對象,目前只能通過圖象來表現這些對象。
3) Html實例置標語言的地位,完全不能適應對新標記需求的發展需要。
XML的出現,使上述問題都得到很好的解決。
試想在互聯網世界,如果大家都講方言,互相交換信息時都要進行翻譯,那將是一個多麼難以溝通和交流的世界。在互聯網世界,XML之所以重要,恰恰是由於它扮演了"國際語言"角色的緣故。此外,XML更為互聯網世界提供了定義各行各業的"專業術語"的工具。
二.如何在浏覽器中閱讀XML?
閱讀XML文檔的工具一般稱為XML解析器, 也稱為XML處理器。 XML處理器將數據傳送到應用軟件, 以便處理, 出版, 查詢, 或顯示。XML不給應用軟件提供 應用程序接口 (API), 它只是把數據傳給應用軟件. XML處理器不解析非構造良好的數據。 Netscape 和 Microsoft 都已經將XML解析器包含在其浏覽器中。 XML開發者團體提供免費的XML閱讀器和解析器, 以便在應用軟件或XML制作軟件中進行應用。
三.為什麼要使用XML而不是Html?
比較重要的原因有以下六條:
1)作者和供應商能使用XML設計自己的文檔類型,不必被Html所約束。
2)由於XML的超文本鏈接能力比HTML強得多,XML提供的信息內容比 Html更豐富,也更易於使用。
3)XML能提供更多更好的機制方便浏覽器的信息表現和優化性能。
4)XML捨棄了SGML的復雜性,因此編寫處理XML的應用程序會很容易。
5)信息易於存儲,可重復使用。
6)XML文件在SGML環境中也可使用,不一定要局限於在WEB中使用。
四.可以用Java創建和管理XML文件嗎?
是的,任何程序設計語言都能被用來從XML形式的源文檔中輸出數據。已經出現了許多的前端和後台工具使得程序設計和數據管理更加方便。下面兩個網址有更加詳細的說明: http://www.markwatson.com/XMLdb_0_1.htm http://developerlife.com
五.為什麼XML文件的分析結果出現亂碼?
這是由編碼問題引起的。XML標准規定,XML分析器必須支持“UTF-8”和“UTF-16”編碼,而且必須能夠自動區分這兩種編碼的文件,對於其他編碼(包括常用的中文編碼“GB2312”或“BIG5”)並不要求支持。如果XML文件中包含編碼聲明,分析器則按照聲明的編碼進行處理,否則就按照識別結果進行處理(識別的結果總是“UTF-8”和“UTF-16”中的一種)。因此,如果XML文件的編碼在這兩種之外,你必須在XML文件前加上編碼聲明,如:<?xml version="1.0" encoding="gb2312"?>就表示XML文件的編碼是“gb2312”。
現有的XML分析器大多不支持中文編碼“GB2312”或“BIG5”,因此無法讀取包含中文的XML文件。你可以使用支持中文編碼的分析器,如MSXML,IBMJAVA4C,IBMJava4J等進行XML分析。你也可以用內碼轉換工具,將編碼轉換為“UTF-8”或“UTF-16”後進行解析,然後將解析結果轉換回原來的編碼。本站的軟件園地中的ccnv(Code Converter)就是這樣的工具。當然,你也可以自己寫一個內碼轉換程序。
關於“UTF-8”和“UTF-16”編碼的詳細信息,請查看本站標准荟萃中的UTF-16和UTF-8標准。
六.XML如何與數據庫連接?
XML是一種文件格式,它沒有規定與數據庫的連接方法,你需要用傳統的方法連接數據庫,進行數據庫查詢,然後將查詢結果轉化為XML格式。現在有一些工具提供了XML與數據庫的連接過程大都遵循這樣的步驟。下面是一個利用ASP直接生成XML文件的例子,你可以訪問http://www.XML.Net.cn/Asps/test/roster1.ASP查看執行效果。
<%@ language="VBScript" %>
<?XML version="1.0" encoding="gb2312"?>
<?XML:stylesheet type="text/xsl" href="..image oster.xsl"?>
<roster>
<%
set cConn = Server.CreateObject("ADODB.Connection")
call cConn.Open("DSN","USER", "PWD")
set rs = cConn.Execute("SELECT DISTINCT * FROM roster")
Do While Not rs.EOF %>
<Record>
<Name><%=trim(rs("name"))%></Name>
<NativePlace><%=trim(rs("NativePlace"))%></NativePlace>
<Age><%=trim(rs("Age"))%></Age>
<Telephone><%=trim(rs("Telephone"))%></Telephone>
</Record>
<% rs.MoveNext
Loop
rs.Close
set rs=nothing
set cConn=nothing
%>
</roster>