php5 dom,在PHP5中使用DOM控制XML

PHP5中增强了XML的支持,使用DOM扩展了XML操作的能耐。这些函数作为 PHP5 核心的一部分,无需被安装即可使用。

下面的例子简单的演示了DOM对XML的操作,详细解释请看代码中的注释

/************************************************

** use XML in PHP5

** reference site:

** http://cn.php.net/manual/zh/ref.dom.php

** the follow codes need PHP5 support

** www.knowsky.com

*************************************************/

//首先要创建一个DOMDocument对象

$dom = new DomDocument();

//然后载入XML文件

$dom -> load("test.xml");

//输出XML文件

//header("Content-type: text/xml;charset=gb2312");

//echo $dom -> saveXML();

//保存XML文件,返回值为int(文件大小,以字节为单位)

//$dom -> save("newfile.xml");

echo "


取得所有的title元素:
";

$titles = $dom -> getElementsByTagName("title");

foreach ($titles as $node)

{

echo $node -> textContent . "
";

//这样也可以

//echo $node->firstChild->data . "
";

}

/*

echo "


从根结点遍历所有结点:
";

foreach ($dom->documentElement->childNodes as $items) {

//如果节点是一个元素(nodeType == 1)并且名字是item就继续循环

if ($items->nodeType == 1 && $items->nodeName == "item") {

foreach ($items->childNodes as $titles) {

//如果节点是一个元素,并且名字是title就打印它.

if ($titles->nodeType == 1 && $titles->nodeName == "title") {

print $titles->textContent . "\n";

}

}

}

}

*/

//使用XPath查询数据

echo "


使用XPath查询的title节点结果:
";

$xpath = new domxpath($dom);

$titles = $xpath->query("/rss/channel/item/title");

foreach ($titles as $node)

{

echo $node->textContent."
";

}

/*

这样和使用getElementsByTagName()方法差不多,但是Xpath要强大的多

深入一点可能是这样:

/rss/channel/item[position() = 1]/title 返回第一个item元素的所有

/rss/channel/item/title[@id = '23'] 返回所有含有id属性并且值为23的title

/rss/channel/&folder&/title 返回所有articles元素下面的title(译者注:&folder&代表目录深度)

*/

//向DOM中写入新数据

$item = $dom->createElement("item");

$title = $dom->createElement("title");

$titleText = $dom->createTextNode("title text");

$title->appendChild($titleText);

$item->appendChild($title);

$dom->documentElement->getElementsByTagName('channel')->item(0)->appendChild($item);

//从DOM中删除节点

//$dom->documentElement->RemoveChild($dom->documentElement->getElementsByTagName("channel")->item(0));

//或者使用xpath查询出节点再删除

//$dom->documentElement->RemoveChild($xpath->query("/rss/channel")->item(0));

//$dom->save("newfile.xml");

//从DOM中修改节点数据

//修改第一个title的文件

//这个地方比较笨,新创建一个节点,然后替换旧的节点。如果哪位朋友有其他好的方法请一定要告诉我

$firstTitle = $xpath->query("/rss/channel/item/title")->item(0);

$newTitle = $dom->createElement("title");

$newTitle->appendChild(new DOMText("This's the new title text!!!"));

$firstTitle->parentNode->replaceChild($newTitle, $firstTitle);

//修改属性

//$firstTitle = $xpath->query("/rss/channel/item/title")->item(0);

//$firstTitle->setAttribute("orderby", "4");

$dom->save("newfile.xml");

echo "


查看newfile.xml";

//下面的代码获得并解析php.net的首页,将返第一个title元素的内容。

/*

$dom->loadHTMLFile("http://www.php.net/");

$title = $dom->getElementsByTagName("title");

print $title->item(0)->textContent;

*/

?>

下面是test.xml文件代码:

javascript

http://blog.csdn.net/zhongmao/category/29515.aspx

javascript

zh-chs

.text version 0.958.2004.2001

zhongmao

out put excel used javascript

http://blog.csdn.net/zhongmao/archive/2004/09/15/105385.aspx

wed, 15 sep 2004 13:32:00 gmt

http://blog.csdn.net/zhongmao/archive/2004/09/15/105385.aspx

http://blog.csdn.net/zhongmao/comments/105385.aspx

http://blog.csdn.net/zhongmao/archive/2004/09/15/105385.aspx#feedback

2

http://blog.csdn.net/zhongmao/comments/commentrss/105385.aspx

http://blog.csdn.net/zhongmao/services/trackbacks/105385.aspx

test description

zhongmao

out put word used javascript

http://blog.csdn.net/zhongmao/archive/2004/08/06/67161.aspx

fri, 06 aug 2004 16:33:00 gmt

http://blog.csdn.net/zhongmao/archive/2004/08/06/67161.aspx

http://blog.csdn.net/zhongmao/comments/67161.aspx

http://blog.csdn.net/zhongmao/archive/2004/08/06/67161.aspx#feedback

0

http://blog.csdn.net/zhongmao/comments/commentrss/67161.aspx

http://blog.csdn.net/zhongmao/services/trackbacks/67161.aspx

test word description

zhongmao

xmlhttp

http://blog.csdn.net/zhongmao/archive/2004/08/02/58417.aspx

mon, 02 aug 2004 10:11:00 gmt

http://blog.csdn.net/zhongmao/archive/2004/08/02/58417.aspx

http://blog.csdn.net/zhongmao/comments/58417.aspx

http://blog.csdn.net/zhongmao/archive/2004

/08/02/58417.aspx#feedback

0

http://blog.csdn.net/zhongmao/comments/commentrss

/58417.aspx

http://blog.csdn.net/zhongmao/services/trackbacks/58417.aspx

xmlhttpaaa asd bb cc dd

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的海滨体育馆管理系统,源码+数据库+毕业论文+视频演示 本基于Spring Boot的海滨体育馆管理系统设计目标是实现海滨体育馆的信息化管理,提高管理效率,使得海滨体育馆管理工作规范化、高效化。 本文重点阐述了海滨体育馆管理系统的开发过程,以实际运用为开发背景,基于Spring Boot框架,运用了Java技术和MySQL作为系统数据库进行开发,充分保证系统的安全性和稳定性。本系统界面良好,操作简单方便,通过系统概述、系统分析、系统设计、数据库设计、系统测试这几个部分,详细的说明了系统的开发过程,最后并对整个开发过程进行了总结,实现了海滨体育馆相关信息管理的重要功能。 本系统的使用使管理人员从繁重的工作解脱出来,实现无纸化办公,能够有效的提高海滨体育馆管理效率。 关键词:海滨体育馆管理,Java技术,MySQL数据库,Spring Boot框架 本基于Spring Boot的海滨体育馆管理系统主要实现了管理员功能模块和学生功能模块两大部分,这两大功能模块分别实现的功能如下: (1)管理员功能模块 管理员登录后可对系统进行全面管理操作,包括个人心、学生管理、器材管理、器材借出管理、器材归还管理、器材分类管理、校队签到管理、进入登记管理、离开登记管理、活动预约管理、灯光保修管理、体育论坛以及系统管理。 (2)学生功能模块 学生在系统前台可查看系统信息,包括首页、器材、体育论坛以及体育资讯等,没有账号的学生可进行注册操作,注册登录后主要功能模块包括个人心、器材管理、器材借出管理、器材归还管理、校队签到管理、进入登记管理、离开登记管理、活动预约管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值