如何使用PHP DOM创建动态XML文件

<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 728x15, 创建于 08-4-23MSDN */ google_ad_slot = "3624277373"; google_ad_width = 728; google_ad_height = 15; //--> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 160x600, 创建于 08-4-23MSDN */ google_ad_slot = "4367022601"; google_ad_width = 160; google_ad_height = 600; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

    当处理基于XML应用程序时,开发者经常需要建立XML编码数据结构。例如,Web中基于用户输入的XML状态模板,服务器请求XML语句,以及基于运行时间参数的客户响应。

    尽管XML数据结构的构建比较费时,但如果使用成熟的PHP DOM应用程序接口,一切都会变得简单明了。本文将向你介绍PHP DOM应用程序接口的主要功能,演示如何生成一个正确的XML完整文件并将其保存到磁盘中。

    创建文档类型声明

    一般而言,XML声明放在文档顶部。在PHP中声明十分简单:只需实例化一个DOM文档类的对象并赋予它一个版本号。查看程序清单A:

程序清单 A

<?PHP
// create doctype
$DOM = new DOMDocument("1.0");

// display document in browser as plain text
// display document in browser as plain text
// for readability purposes
header("Content-Type: text/plain");

// save and display tree
echo $DOM->saveXML();
?>

    请注意DOM文档对象的saveXML()方法。稍后我再详细介绍这一方法,现在你只需要简单认识到它用于输出XML文档的当前快照到一个文件或浏览器。在本例,为增强可读性,我已经将ASCII码文本直接输出至浏览器。在实际应用中,可将以text/XML文件发送到浏览器。

    如在浏览器中查看输出,你可看到如下代码:

<?XML version="1.0"?>

    添加元素和文本节点

    XML真正强大的功能是来自其元素与封装的内容。幸运的是,一旦你初始化DOM文档,很多操作变得很简单。此过程包含如下两步骤:

    对想添加的每一元素或文本节点,通过元素名或文本内容调用DOM文档对象的createElement()或createTextNode()方法。这将创建对应于元素或文本节点的新对象。
通过调用节点的appendChild()方法,并把其传递给上一步中创建的对象,并在XML文档树中将元素或文本节点添加到父节点。
以下范例将清楚地演示这2步骤,请查看程序清单B。

    程序清单 B

<?PHP
// create doctype
$DOM = new DOMDocument("1.0");

// display document in browser as plain text
// for readability purposes
header("Content-Type: text/plain");

// create root element
$root = $DOM->createElement("toppings");
$DOM->appendChild($root);

// create child element
$item = $DOM->createElement("item");
$root->appendChild($item);

// create text node
$text = $DOM->createTextNode("pepperoni");
$item->appendChild($text);

// save and display tree
echo $DOM->saveXML();
?>

    这里,我首先创建一个名字为<toppings>的根元素,并使它归于XML文件中。然后,我建立名为<item>的元素并使它归于根元素。最后,我又创建一个值为“pepperoni”的文本节点并使它归于<item>元素。最终结果如下:

<?XML version="1.0"?>
<toppings>
?<item>pepperoni</item>
</toppings>

    如果你想添加另外一个topping,只需创建另外一个<item>并添加不同的内容,如程序清单C所示。

程序清单C

<?PHP
// create doctype
$DOM = new DOMDocument("1.0");

// display document in browser as plain text
// for readability purposes
header("Content-Type: text/plain");

// create root element
$root = $DOM->createElement("toppings");
$DOM->appendChild($root);

// create child element
$item = $DOM->createElement("item");
$root->appendChild($item);

// create text node
$text = $DOM->createTextNode("pepperoni");
$item->appendChild($text);

// create child element
$item = $DOM->createElement("item");
$root->appendChild($item);

// create another text node
$text = $DOM->createTextNode("tomato");
$item->appendChild($text);

// save and display tree
echo $DOM->saveXML();
?>

以下是执行程序清单C后的输出:

<?XML version="1.0"?>
<toppings>
?<item>pepperoni</item>
?<item>tomato</item>
</toppings>

    添加属性
 
    通过使用属性,你也可以添加适合的信息到元素。对于PHP DOM API,添加属性需要两步:首先用DOM文档对象的createAttribute()方法创建拥有此属性名字的节点,然后将文档节点添加到拥有属性值的属性节点。详见程序清单D。

程序清单 D

<?PHP
// create doctype
$DOM = new DOMDocument("1.0");

// display document in browser as plain text
// for readability purposes
header("Content-Type: text/plain");
// create root element
$root = $DOM->createElement("toppings");
$DOM->appendChild($root);

// create child element
$item = $DOM->createElement("item");
$root->appendChild($item);

// create text node
$text = $DOM->createTextNode("pepperoni");
$item->appendChild($text);

// create attribute node
$price = $DOM->createAttribute("price");
$item->appendChild($price);

// create attribute value node
$priceValue = $DOM->createTextNode("4");
$price->appendChild($priceValue);

// save and display tree
echo $DOM->saveXML();
?>

输出如下所示:

<?XML version="1.0"?>
<toppings>
?<item price="4">pepperoni</item>
</toppings>

    添加CDATA模块和过程向导

    虽然不经常使用CDATA模块和过程向导,但是通过调用DOM文档对象的createCDATASection()和createProcessingInstruction()方法, PHP API 也能很好地支持CDATA和过程向导,请见程序清单E。

程序清单 E

<?PHP
// create doctype
// create doctype
$DOM = new DOMDocument("1.0");

// display document in browser as plain text
// for readability purposes
header("Content-Type: text/plain");

// create root element
$root = $DOM->createElement("toppings");
$DOM->appendChild($root);

// create child element
$item = $DOM->createElement("item");
$root->appendChild($item);

// create text node
$text = $DOM->createTextNode("pepperoni");
$item->appendChild($text);

// create attribute node
$price = $DOM->createAttribute("price");
$item->appendChild($price);

// create attribute value node
$priceValue = $DOM->createTextNode("4");
$price->appendChild($priceValue);

// create CDATA section
$cdata = $DOM->createCDATASection("/nCustomer requests that pizza be sliced into 16 square pieces/n");
$root->appendChild($cdata);

// create PI
$pi = $DOM->createProcessingInstruction("pizza", "bake()");
$root->appendChild($pi);

// save and display tree
echo $DOM->saveXML();
?>
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 728x15, 创建于 08-4-23MSDN */ google_ad_slot = "3624277373"; google_ad_width = 728; google_ad_height = 15; //--> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 160x600, 创建于 08-4-23MSDN */ google_ad_slot = "4367022601"; google_ad_width = 160; google_ad_height = 600; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
阅读更多
个人分类: 网络技术
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭