一、小序
HTML簡單易學又通用,一般的PHP程式就是嵌入在HTML語言之中實現的。但是隨著WEB越來越廣泛的應用,HTML的弱點也越來越明顯了。XML的出現,彌補了這些不足,它提供了一個能夠處理互連網上全部資料的通用方法。
二、HTML的局限性分析
1、 HTML的可擴充性差。雖然作為一般的應用,HTML應經夠用了,但是在處理數學和化學等符號時,HTML有明顯的缺點,而且它無法進行擴充,這樣使它的發展收到了極大的限制。
2、 鏈路丟失後不能自動糾正。由於Web頁面的URL地址經常改變,而在改變URL地址時必須手工修改這些資訊,否則就會遇到“404URL地址未找到”的資訊,這大大加重了Web頁面的維護工作量。
3、 資料搜尋的時間長。由於HTML主要用來對網頁的顯示進行控制,導致了同一個資料在不同的網頁中有不同的儲存格式,這樣在進行資料搜尋時就無法快速找到所需的資料。
4、 HTML對雙位元組或者多國文字的支援不夠。例如中文資訊頁面在不同的平台下會出現無法顯示等問題。
正是由於這些缺點,人們研究了能夠代替HTML的Web頁面製作語言。其中已經投入使用的有:可延伸標記語言 (XML)XML、層疊樣式表(CSS)以及動態HTML(DHTML)等。
三、XML的組成
這裡簡要列舉幾種主要的XML技術:
1、 DTD(文件類型聲明)
DTD的主要功能是定義XML的內容模式;限制XML標記的資料範圍;定義屬性的資料類型。但由於它不是用XML編寫的,因此擴充性比較差;而且只提供了有限的幾種資料類型,因此它的作用是有限的。
2、 XML Schema
XML Schema的作用和DTD類似。但不同的是,Schema檔案所描述的是引用它的XML檔案中的元素和屬性的具體類型。另外,由於它是由XML編寫的,Schema和DTD相比較還有以下優點:
·XML Schema內容模型是開放的,可以隨意擴充,而DTD無法解析擴充的內容。
·DTD只能把內容類型定義為一個字串,而XML Schema允許把內容類型定義為整型、浮點型、布爾型或者許多其它的單一資料型別。
·XML Schema利用Namespaces將文檔中特殊的節點與Schema相聯絡,一個XML檔案可以有多個對應的Schema,而一個XML檔案只能有一個DTD。
3、 XLink
作為一種Web語言,XML的連結能力是非常重要的。XML的連結和定址機制包括XLink、XPath和XPointer。XLink提供功能強大的連結方法,可以在文檔之間建立單向或多向的複雜連接關係,還有注釋連結、概要連結、擴充連結集等多種連結功能。XPath在XSLT和XPointer中使用,支援在XML文檔中相對於節點和節點集的定位。XPointer在XPath的基礎上提供對XML文檔的內容的內部結構(如一個字串或者選擇的一個段落)的定位。XML的連結能力比HTML有了很大的增強。
4、 CSS與XSL
XML的一大特點就是內容與格式分離,也就是說,XML文檔中並不包含如何顯示/表示文檔的資訊。CSS與XSL(XML Style Language)解決了XML文檔的顯示問題。
CSS(層疊樣式表)也可以用在HTML和XML中。XSL完全使用XML的文法,功能比CSS要強大得多。
5、 DOM
文件物件模型(DOM)是一個與平台、語言無關的程式介面,它提供了動態訪問和更新文檔的內容、結構與風格的手段。可以對文當作進一步的處理,並將處理的結果更新到表示頁面。
DOM的目標就是為XML和HTML定義一個標準的編程介面,它包括核心、HTML和XML三部分。DOM的核心部分建立了一套底層的對象集,它們可以表示任何結構化的文檔。HTML和XML提供了高層的介面,可以作為更方便的文檔視圖。DOM規範由對象和方法組成。程式員使用它們可以更容易地對特定類型的文檔進行訪問和操作。
6、 Namespaces
Namespaces是用URL加以區別的、在XML檔案的元素和屬性中出現的所有名稱的集合。在XML中,使用者可以自己定義標記和元素。因此,如果把多個XML檔案合并為一個,就很可能出現衝突。Namespaces則解決了這個問題。
四、PHP對XML的支援
PHP對XML提供了的強大的支援。它使用了一個XML的“解析器”,並且為了支援這個解析器,它提供了20(PHP4)個XML的解析函數。下面是幾個最常用的PHP解析函數。
1. xml_parse
boolean xml_parse(int parser, string data, int [isFinal]);
本函數用來解析 XML 格式的檔案資料。參數 parser 為解析代碼。參數 data 為解析的資料區塊 (chunk)。參數 isFinal 可省略,若設為 true 則系統會自動送出最後的資料部分 (piece) 給 data 參數。若無錯誤則返回 true 值。
2. xml_parser_create
int xml_parser_create(string [encoding]);
本函數用來初始化一個新的 XML 解析器。參數 encoding 可省略,為 XML 使用的字元集,預設值為 ISO-8859-1,其它尚有 US-ASCII、UTF-8 二種。成功則返回 parser 代碼供其它函數使用,失敗則返回 false 值。
3. xml_set_element_handler
boolean xml_set_element_handler(int parser, string startElementHandler, string endElementHandler);
本函數配置元素的標題供 xml_parse() 函數使用。參數 parser 為解析代碼。參數 startElementHandler 及 endElementHandler 分別為元素開始與結束的標題,其中的 startElementHandler 必須包括解析代碼、名稱、與屬性,而 endElementHandler 參數包括瞭解析代碼及名稱二個參數。若無錯誤則返回 true 值。
4. xml_set_character_data_handler
boolean xml_set_character_data_handler(int parser, string handler);
本函數配置字元資料的標題。參數 parser 為解析代碼。參數 handler 包括解析代碼及資料字串等二個元素。若無錯誤則返回 true 值。
5. xml_get_error_code
int xml_get_error_code(int parser);
本函數可取得 XML 在處理時的錯誤碼。參數 parser 為解析代碼。若 parser 有錯則返回 false 值,否則就返回錯誤碼 (如 XML_ERROR_BINARY_ENTITY_REF .... 等等)。
6. xml_error_string
string xml_error_string(int code);
本函數可取得 XML 在處理時的錯誤碼。參數 code 為解析錯誤碼。若無錯誤傳回值為代碼的文字描述字串。
7. xml_get_current_line_number
int xml_get_current_line_number(int parser);
本函數用來取得目前 XML 解析所正在處理的行號。參數 parser 為解析代碼。若 parser 有錯則返回 false 值,若無錯誤則返回行號數字。
8. xml_parser_free
boolean xml_parser_free(int parser);
本函數用來釋放目前 XML 解析所使用的記憶體。參數 parser 為解析代碼。若沒有錯誤則返回 true 值,否則返回 false 值。