dougu2036 2018-03-22 22:31
浏览 39
已采纳

PHP SimpleXML - 获得价值

I am trying to use SimpleXML with PHP to get a value from XML stored in a database. A portion of my XML looks like this:

<?xml version="1.0" encoding="UTF-8"?>
<java version="1.8.0_161" class="java.beans.XMLDecoder">
  <object class="atavism.agis.objects.AgisMob" id="AgisMob0">
  <void property="name">
    <string>Rachels</string>
  </void>
  <void property="oid">
  <object class="atavism.server.engine.OID" id="OID0">
  <void property="data">
    <long>41321</long>
  </void>

I also have other XML in the same "document" that looks like this:

So that being said, I would probably need to fetch it where the property attribute is equal to "name". I do plan on getting other information from this document later on as well, just need to figure out how.

Here is the code I have so far:

$blob_query = mysqli_query($dbh8, "SELECT * FROM objstore WHERE obj_id='$characterId' AND type='PLAYER' AND namespace_int='3' ORDER BY obj_id DESC LIMIT 1");           
        if($blob_query){
            $blob_row = mysqli_fetch_assoc($blob_query);
            $data = $blob_row['data'];

            $xml=simplexml_load_string($data) or die("Error: Cannot create object");
            echo $xml->void[0]->string;

        }

It is not displaying anything. It should be displaying "Rachels". Any help is very much appreciated!

  • 写回答

2条回答 默认 最新

  • doupafu6980 2018-03-22 23:25
    关注

    You're missing the <object> tag to get <string> tag content.

    Assuming you XML look likes (as a valid XML):

    $data = '<?xml version="1.0" encoding="UTF-8"?>
    <java version="1.8.0_161" class="java.beans.XMLDecoder">
      <object class="atavism.agis.objects.AgisMob" id="AgisMob0">
          <void property="name">
            <string>Rachels</string>
          </void>
      </object>
      <void property="oid">
          <object class="atavism.server.engine.OID" id="OID0">
              <void property="data">
                <long>41321</long>
              </void>
          </object>
      </void>
    </java>';
    

    You have to use:

    $xml=simplexml_load_string($data) or die("Error: Cannot create object");
    echo $xml->object->void[0]->string;
    

    outputs:

    Rachels
    

    Note also that [0] is not necessary (in this case):

    echo $xml->object->void->string;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题