Search code examples
phparraysxmlapisimplexml

PHP parse xml to array


i need to convert an xml to array. I get the xml from an online api. My code so far:

function download_page($path){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$path);
curl_setopt($ch, CURLOPT_FAILONERROR,1);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION,1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_TIMEOUT, 15);
$retValue = curl_exec($ch);          
curl_close($ch);
return $retValue;
}
$sXML = download_page('https://url/api/user/distgroup/domain/user?t=ticketofuser');
echo "xml start: ". htmlentities($sXML);
$oXML = new SimpleXMLElement($sXML);

echo "xml: ". $oXML;
foreach($oXML["distributionGroups"] as $key=>$value)
{
  $groups[$key]["group"]["id"]=$value["id"];
    $groups[$key]["group"]["domain"]=$value["domain"];
    $groups[$key]["group"]["name"]=$value["name"];
    $groups[$key]["group"]["type"]=$value["type"];
    $groups[$key]["group"]["loggedIn"]=$value["loggedIn"];
    $groups[$key]["group"]["nightMode"]=$value["nightMode"];

    $groups[$key]["group"]["loggedInAgents"]=$value["loggedInAgents"];
    $groups[$key]["group"]["freeAgents"]=$value["freeAgents"];
    $groups[$key]["group"]["callsWaiting"]=$value["callsWaiting"];
}
$temp=array();
    foreach ($groups as $key => $row) {
         $temp[$key]  = $row["id"]; 
}
    array_multisort($temp, SORT_ASC, $groups);
    $_SESSION["groups"]=$groups;

    echo "groups: ". $groups;

Afterdownloaded the xml it looks like this when i echo it with htmlentities($sXML);

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<distributionGroups>
<group>
<id>33247</id>
<domain>soluno.se</domain>
<name>Kamoda Support</name>
<type>ATTENDANT</type>
<loggedIn>true</loggedIn>
<nightMode>false</nightMode>
<loggedInAgents>1</loggedInAgents>
<freeAgents>1</freeAgents>
<callsWaiting>0</callsWaiting>
</group>
<group>
<id>33257</id>
<domain>soluno.se</domain>
<name>Test 5</name>
<type>ATTENDANT</type>
<loggedIn>false</loggedIn>
<nightMode>false</nightMode>
<loggedInAgents>0</loggedInAgents>
<freeAgents>0</freeAgents>
<callsWaiting>0</callsWaiting>
</group>
</distributionGroups>

My problem is that my array is empty after my try to foreach fill the array. What am i doing wrong?


Solution

  • In your second foreach, you are missing the key group. Also, you could use $oXML->group to iterator over the XML elements:

    $oXML = new SimpleXMLElement($sXML);
    $groups = [] ;
    foreach($oXML->group as $group)
    {
        $groups[]["group"] = [
            'id' => (string)$group->id,
            'domain' => (string) $group->domain,
            'name' => (string) $group->name,
            'type' => (string) $group->type,
            'loggedIn' => (string) $group->loggedIn,
            'nightMode' => (string) $group->nightMode,
            'loggedInAgents' => (string) $group->loggedInAgents,
            'freeAgents' => (string) $group->freeAgents,
            'callsWaiting' => (string) $group->callsWaiting,
        ];
    }
    $temp=array();
    foreach ($groups as $key => $row) {
        $temp[$key]  = $row['group']["id"]; // missing 'group' in $row['group']
    }
    array_multisort($temp, SORT_ASC, $groups);
    
    print_r($temp);
    print_r($groups);
    

    Output of $temp:

    Array
    (
        [0] => 33247
        [1] => 33257
    )
    

    Output of $groups:

    Array
    (
        [0] => Array
            (
                [group] => Array
                    (
                        [id] => 33247
                        [domain] => soluno.se
                        [name] => Kamoda Support
                        [type] => ATTENDANT
                        [loggedIn] => true
                        [nightMode] => false
                        [loggedInAgents] => 1
                        [freeAgents] => 1
                        [callsWaiting] => 0
                    )
    
            )
    
        [1] => Array
            (
                [group] => Array
                    (
                        [id] => 33257
                        [domain] => soluno.se
                        [name] => Test 5
                        [type] => ATTENDANT
                        [loggedIn] => false
                        [nightMode] => false
                        [loggedInAgents] => 0
                        [freeAgents] => 0
                        [callsWaiting] => 0
                    )
    
            )
    
    )
    

    Or you could remove "group" in your first array :

    $oXML = new SimpleXMLElement($sXML);
    $groups = [] ;
    foreach($oXML->group as $group)
    {
        $groups[] = [
            'id' => (string)$group->id,
            'domain' => (string) $group->domain,
            'name' => (string) $group->name,
            'type' => (string) $group->type,
            'loggedIn' => (string) $group->loggedIn,
            'nightMode' => (string) $group->nightMode,
            'loggedInAgents' => (string) $group->loggedInAgents,
            'freeAgents' => (string) $group->freeAgents,
            'callsWaiting' => (string) $group->callsWaiting,
        ];
    }
    $temp=array();
    foreach ($groups as $key => $row) {
        $temp[$key]  = $row["id"];
    }
    array_multisort($temp, SORT_ASC, $groups);