PHP实现动态删除XML数据的方法示例

 2025-01-15  阅读 500  评论 8  点赞 389

摘要:本文实例讲述了php实现动态删除xml数据的方法。分享给大家供大家参考,具体如下: 前面介绍了动态添加xml数据的方法,这里在原有message_xml类的基础上稍作改进,实现动态删除xml的功能: 一. 代码 loadxml($xmlstr); $this->save("message.xml");//生成xml文档 }else{ $this

本文实例讲述了php实现动态删除xml数据的方法。分享给大家供大家参考,具体如下:

PHP实现动态删除XML数据的方法示例

前面介绍了动态添加xml数据的方法,这里在原有message_xml类的基础上稍作改进,实现动态删除xml的功能:

一. 代码


<?php
  class message_xml extends domdocument{//定义类message_xml并继承domdocument类
   private $root;
   public function __construct(){//构造函数
    parent:: __construct();
    if(!file_exists("message.xml")){//判断文件是否存在
     $xmlstr="<?xml version='1.0' encoding='gb2312'?><message></message>";
     $this->loadxml($xmlstr);
     $this->save("message.xml");//生成xml文档
    }else{
     $this->load("message.xml");//如果存在则载入xml文档
    }
   }
   public function add_message($user,$address){//创建方法
    $root=$this->documentelement;//定义根节点
    $admin_id=date("ynjhis");
    $node_admin_id=$this->createelement("admin_id");//创建节点admin_id
    $text=$this->createtextnode(iconv("gb2312","utf-8",$admin_id));//创建一个文本节点
    $node_admin_id->appendchild($text);//将文本节点添加到admin_id节点中
    $node_user=$this->createelement("user");//创建节点user
    $text=$this->createtextnode(iconv("gb2312","utf-8",$user));//创建一个文本节点
    $node_user->appendchild($text);//将文本节点添加到user节点中
    $node_address=$this->createelement("address");//创建节点address
    $text=$this->createtextnode(iconv("gb2312","utf-8",$address));//创建一个文本节点
    $node_address->appendchild($text);//将文本节点添加到address节点中
    $node_record=$this->createelement("record");//创建节点record
    $node_record->appendchild($node_admin_id);//将admin_id节点添加到record节点中
    $node_record->appendchild($node_user);//将user节点添加到record节点中
    $node_record->appendchild($node_address);//将address节点添加到record节点中
    $root->appendchild($node_record);//将record节点添加到根节点中
    $this->save("message.xml");//生成xml文档
    echo "<script>alert('添加成功');location.href='".$_server['php_self']."'</script>";
   }
   public function delete_message($admin_id){//定义删除函数
    $root=$this->documentelement;//定义根节点
    $xpath=new domxpath($this);//定义domxpath
    $node_record=$xpath->query("//record[admin_id='$admin_id']");//执行查询语句
    $root->removechild($node_record->item(0));//删除节点
    $this->save("message.xml");//生成xml文档
    echo "<script>alert('删除成功');location.href='".$_server['php_self']."'</script>";
   }
   public function show_message(){//定义输出xml文件中的内容函数
    $root=$this->documentelement;//定义根节点
    $xpath=new domxpath($this);//定义domxpath
    $node_record=$this->getelementsbytagname("record");//获取节点record的标签
    $node_record_length=$node_record->length;//获取标签的数量
    print"<table width='506' bgcolor='#ffffcc'><tr>";
    print"<td width='106' height='22' align='center'>";
    print"<b>用户名</b>";
    print"</td><td width='300' align='center'>";
    print"<b>留言信息</b></td></tr>";
    for($i=0;$i<$node_record->length;$i++){//应用for循环输出查询结果
     $k=0;
     foreach($node_record->item($i)->childnodes as $articles){  //通过foreach语句读取返回对象中的数据
      $field[$k]=iconv("utf-8","gb2312",$articles->textcontent);//实现编码格式的转换
      $k++;
     }
     print"<table width='506' bgcolor='#ffffcc'><tr>";
     print"<td width='106' height='22' align='center'>";
     print"$field[1]";
     print"</td><td width='300' align='center'>";
     print"$field[2]";
     print"</td><td width='100' align='center'>";
     print"<a href='?action=delete_message&admin_id=$field[0]'>删除</a></td>";
     print"</tr></table>";
    }
   }
   public function post_message(){
    print"<table width='506' bgcolor='#ffffcc'><form method='post' action='?action=add_message'>";
    print"<tr><td width='106' height='22'>    用户名:</td><td><input type='text' name='user' size=50></td></tr>";
    print"<tr><td width='106' height='22'>    留言信息:</td><td width='400'><textarea name='address' cols='48' rows='5' id='address'></textarea></td></tr>";
    print"<tr><td width='106' height='30'>  <input type='submit' value='添加数据'></td><td align='right'><a href='?action=show_message'>查看数据</a>    </td></tr></form></table>";
   }
  }
?>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=gb2312" />
<title>删除xml数据</title>
<style type="text/css">
<!--
body,td,th {
  font-size: 12px;
}
-->
</style></head>
<body>
<table width="506" height="50" border="0" cellpadding="0" cellspacing="0" bgcolor="#33be6b">
 <tr>
  <td width="506" height="50" valign="bottom" background="title.gif">
   <table width="506">
    <tr>
     <td height="24" align="right" scope="col">  <a href="?action=post_message" rel="external nofollow" >添加数据</a>   </td></tr></table></td></tr>
     <?php
      $hawkxml=new message_xml;//实例化message_xml类
      $action="";//初始化为空值
      if(isset($_get['action'])) $action=$_get['action'];
      switch($action){
       case "show_message":
       $hawkxml->show_message();//当参数值为show_message时执行show_message()函数
       break;
       case "post_message":
       $hawkxml->post_message();//当参数值为post_message时执行post_message()函数
       break;
       case "add_message":
       $hawkxml->add_message($_post['user'],$_post['address']);//当参数值为add_message时执行add_message()函数
       break;
       case "delete_message":
       $hawkxml->delete_message($_get['admin_id']);//当参数值为delete_message时执行delete_message()函数
       break;
      }
     ?>
</table>
</body>
</html>

二. 运行结果

ps:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:

在线xml/json互相转换工具:
http://tools.jb51.net/code/xmljson

在线格式化xml/在线压缩xml:
http://tools.jb51.net/code/xmlformat

xml在线压缩/格式化工具:
http://tools.jb51.net/code/xml_format_compress

xml代码在线格式化美化工具:
http://tools.jb51.net/code/xmlcodeformat

更多关于php相关内容感兴趣的读者可查看本站专题:《php针对xml文件操作技巧总结》、《php数组(array)操作技巧大全》、《php字符串(string)用法总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家php程序设计有所帮助。


标签:phpphp教程

评论列表:

  •   haliluya
     发布于 3天前回复该评论
  • 写的很不错,学到了!
  •   xiaoming22
     发布于 3天前回复该评论
  • 写的很不错,学到了!
  •   henbucuo
     发布于 3天前回复该评论
  • 写的很不错,学到了!
  •   xiaoming22
     发布于 2天前回复该评论
  • 写的很不错,学到了!
显示更多评论

发表评论:

管理员

承接各种程序开发,外贸网站代运营,外贸网站建设等项目
  • 内容2460
  • 积分67666
  • 金币86666

Copyright © 2024 LS'Blog-保定PHP程序员老宋个人博客 Inc. 保留所有权利。 Powered by LS'blog 3.0.3

页面耗时0.0280秒, 内存占用1.95 MB, 访问数据库30次

冀ICP备19034377号