Skip to main content

php array to xml example

This is an example of generating an xml output format from the database.
This code is creating a sample rss feed from the joomla articles (which can be added to a rss.xml file).

<?php
    $dbhost = "localhost";
    $dbuser = "root";
    $dbpass = "";
    $dbname = "joomla";

    mysql_connect($dbhost,$dbuser,$dbpass);
    mysql_select_db($dbname);
    mysql_query("SET NAMES 'utf8'"); // to get proper format
   
    $sql = "SELECT id, title, alias, title_alias, metadesc FROM `jos_content`
    where catid=12 limit 3";
    $q   = mysql_query($sql) or die(mysql_error());
    $xml = "";

    while($r = mysql_fetch_array($q)){
      $xml .= "<item>";
      $xml .= "<title>".trim($r['title'])."</title>";
      $xml .= "<link>".trim($r['title_alias'])."</link>";
      $xml .= "<pubDate>Fri, 06 Jan 2012 08:30:00 GMT</pubDate>";
      $xml .= "<description>".trim($r['metadesc'])."</description>";
      $xml .= "</item>";
    }

    header("content-type: application/xml;");
    echo $xml;
    ?>

Note: Run the file. If you dont see the xml output, try to view the source code...

Comments

Popular posts from this blog

Joomla validate chrono forms using jquery

It is a common practice to use Chrono forms in our joomla site to setup various forms in the site, be it a contact us form, submit a ticket form, or whatever. I have set the option "validate form" to "No" under chronoform settings in admin panel, and also preferred to not include any js or css files. For validating the chrono forms, i prefer jquery. So first lets add jquery support in our joomla. It is quite simple: 1. Download jquery.js and jquery_min.js (1.4.2 version is enough) and place them in media/system/js folder of your joomla. 2. Edit libraries->joomla->html->html->behavior.php, and add the following function below the mootools() function: function jQuery($debug = null)     {         static $loaded;         global $mainframe;         // Only load once         if ($loaded) {    ...

joomla remove category name in url

-) If anyone is using the lyftenbloggie component, and want to remove the component name and category title from the sef url, follow this hack: (Note: You also need to install the lyftenbloggie extension for ARTIO SEF) Under components/com_sef/joomsef.php, After this code: $location = array();         foreach ($title as $titlePart) {             if (strlen($titlePart) == 0) continue;             $location[] = JoomSEF::_titleToLocation($titlePart);         } Just add this code: if($location[0] == 'lyftenbloggie')         {         $temp_sef = end($location);         $location = array();            $location[] = $temp_sef;         ...

php get content between tags

This involves parsing the dom document. <?php function getTextBetweenTags($tag, $html) {     $dom = new domDocument;     @$dom->loadHTML($html);         $dom->preserveWhiteSpace = false;     $content = $dom->getElementsByTagname($tag);     $out = array();         foreach ($content as $item)     {         $out[] = $item->nodeValue;     }     return $out; } $xhtml = '<tag>abc def</tag><tag>123 456</tag>'; $content2 = getTextBetweenTags('tag', $xhtml); foreach( $content2 as $item ) {     echo $item.'<br />'; } ?> Output: abc def 123 456