Skip to content
Derek Jones edited this page Jul 5, 2012 · 14 revisions

Category:Library | Category:Library::XML | Category:Library::Community

The XML library is an XML parser. It currently has limited features, and is more of a helper library.

Updates

2006-11-06:

  • Allow better recursion, at the cost of increasing depth of all elements
  • Add attributes for all non-bottom depth tags

Features:

  • XML file loading
  • XML -> array parsing
  • Attribute parsing of all non-bottom tags
  • written for PHP5 (not PHP4 compatible)

Usage

$this->load->library('xml');
if ($this->xml->load('data/forms/login')) { // Relative to APPPATH, ".xml" appended
  print_r($this->xml->parse());
}

Library Code

<?php  if (!defined('BASEPATH')) exit('No direct script access allowed');

/***
 * XML library for CodeIgniter
 *
 *    author: Woody Gilk
 * copyright: (c) 2006
 *   license: http://creativecommons.org/licenses/by-sa/2.5/
 *      file: libraries/Xml.php
 */

class Xml {
  function Xml () {
  }

  private $document;
  private $filename;

  public function load ($file) {
    /***
     * @public
     * Load an file for parsing
     */
    $bad  = array('|//+|', '|\.\./|');
    $good = array('/', '');
    $file = APPPATH.preg_replace ($bad, $good, $file).'.xml';

    if (! file_exists ($file)) {
      return false;
    }

    $this->document = utf8_encode (file_get_contents($file));
    $this->filename = $file;

    return true;
  }  /* END load */

  public function parse () {
    /***
     * @public
     * Parse an XML document into an array
     */
    $xml = $this->document;
    if ($xml == '') {
      return false;
    }

    $doc = new DOMDocument ();
    $doc->preserveWhiteSpace = false;
    if ($doc->loadXML ($xml)) {
      $array = $this->flatten_node ($doc);
      if (count ($array) > 0) {
        return $array;
      }
    }

    return false;
  } /* END parse */

  private function flatten_node ($node) {
    /***
     * @private
     * Helper function to flatten an XML document into an array
     */

    $array = array();

    foreach ($node->childNodes as $child) {
      if ($child->hasChildNodes ()) {
        if ($node->firstChild->nodeName == $node->lastChild->nodeName && $node->childNodes->length > 1) {
          $array[$child->nodeName][] = $this->flatten_node ($child);
        }
        else {
          $array[$child->nodeName][] = $this->flatten_node($child);

          if ($child->hasAttributes ()) {
            $index = count($array[$child->nodeName])-1;
            $attrs =& $array[$child->nodeName][$index]['__attrs'];
            foreach ($child->attributes as $attribute) {
              $attrs[$attribute->name] = $attribute->value;
            }
          }
        }
      }
      else {
        return $child->nodeValue;
      }
    }

    return $array;
  } /* END node_to_array */
}

?>
Clone this wiki locally