Číst soubory XML už umíme. Ale jak je zapisovat? Ukažme si na několik způsobů.
22.10.2004 15:00 | Petr Zajíc | czytane 38319×
RELATED ARTICLES
KOMENTARZE
V předchozích dvou dílech seriálu jsme si ukázali, jak pomocí funkcí
parseru číst hotové dokumenty XML. To se samozřejmě hodí v případě, kdy
již máme nějaký ten XML soubor k dispozici. Co ale dělat v případě, kdy
naopak bude chtít někdo XML soubor po nás?
Taková situace není nereálná. Jelikož, jak jsme uvedli, slouží XML
převážně pro výměnu dat, může nějaký externí systém požadovat po naší
aplikaci data v XML. Projděme si tedy několik způsobů, jak takovou
úlohu splnit.
Ruční způsob
S tímto způsobem jsme se již seznámili v díle o exportu dat
z MySQL. Jen připomenu, že se jednalo o přímý zápis dat a značky se
dopisovaly do výstupního souboru (nebo do výstupního proudu) ručně.
Tento způsob je pracný a zejména při vytváření složitěji
strukturovaných XML dokumentů můžeme snadno udělat chybu. Jádro kódu
pro export dat do XML vypadalo následovně:
<?
echo("<obce>\n");
while ($row = mysql_fetch_assoc ($vysledek))
{
echo ("\t<obec>\n");
echo ("\t\t<psc>\n");
echo "\t\t\t".$row["psc"]."\n";
echo ("\t\t</psc>\n");
echo ("\t\t<nazev>\n");
echo "\t\t\t".$row["obec"]."\n";
echo ("\t\t</nazev>\n");
echo ("\t</obec>\n");
}
echo("</obce>\n");
?>
Ruční způsob nedoporučuji. Povede nejspíš ke zmatkům; nemluvě o
situaci, kdy budeme potřebovat změnit strukturu exportovaného
dokumentu. Daleko lepší bude poohlédnout se po nějakém elegantnějším
řešení.
Serializer
Jednou z mnoha možností je využít hotovou knihovnu serializer. Té
stačí
předat pole (nebo objekt) a seznam voleb, a vrátí hotový XML dokument.
Nejprve to předveďme:
<?
//data
require("Serializer.php");
// zde je include souboru s
konstantami
mysql_connect(SQL_HOST, SQL_USERNAME, SQL_PASSWORD);
mysql_select_db(SQL_DBNAME);
$vysledek = mysql_query ("SELECT * FROM psc WHERE
psc=47001");
while ($row = mysql_fetch_array($vysledek))
$xml[] = array ( "nazev" => $row[0], "psc" => $row[1]);
//serializace
$options = array( "addDecl" => true, "defaultTagName"
=> "obec",
"linebreak" => "", "encoding" => "UTF-8", "rootName" => "obce");
$serializer = new XML_Serializer($options);
$serializer->serialize($xml);
// výstup
header("Content-Type: text/xml");
echo $serializer->getSerializedData();
?>
Spustit
skript
Poznamenejme rovnou, že tento způsob je daleko elegantnější než
ruční varianta. Rovněž stojí za zmínku, že v případě většiny exportů
(například, v případě exportu z jedné MySQL tabulky) bude vytvoření
pole poměrně triviální záležitost a tudíž celý kód nejenom dobře
poběží, ale bude rovněž hezky vypadat.
Pozn.: To je vidět na příkladu výše.
Povšimněme si, že zatímco funkce mysql_fetch_array vkládá každý řádek
do pole, funkce array vkládá toto pole ... (ano!) zase do pole. $xml je
jednorozměrné pole tvořené prvky, z nichž každý je rovněž jednorozměrné
pole. Komu se z toho točí hlava, může nahlédnout do dílu seriálu
o polích.
DOM
DOM, neboli Document Object Model je jiný mechanizmus pro čtení
(anebo zápis) XML dokumentů. Spočívá v tom, že se celý XML dokument
nejprve načte do paměti, tam se zanalyzuje a pak se k němu přistupuje
pomocí objektového modelu. To zní dobře. Podpora DOM je implementována
v mnoha programovacích jazycích, v PHP však není
tak dobrá, jak by mohla být. Pokud znáte mechanismus fungování DOM z
jiných programovacích jazyků, pravděpodobně po něm sáhnete i v PHP.
Měli byste ale mít na paměti následující věci:
- PHP musí být přeloženo s podporou DOM. Pokud nebude, nebude Vám
fungovat ani související kód
- Některé DOM funkce zastarávají. Jak se PHP vyvíjí, jeho
implementace DOM prochází rovněž bouřlivým vývojem (momentálně je
zastaralých 18(!) funkcí, což by mě rozhodně rozladilo, kdybych DOM v
PHP používal)
- Implementace DOM se LIŠÍ v PHP4 a PHP5. Takže, v "pětce" Vám
"čtyřkový" kód volající DOM může a nemusí fungovat.
- Pokud chcete ladit (nebo provozovat?) PHP na Windows, pamatujte
na to, že instalace a konfigurace DOM pro PHP může znamenat roční
kopírování knihoven do systémové složky.
Ostatní
Uvedené metody pochopitelně nejsou jediné způsoby, jak s pomocí PHP
vytvářet XML dokumenty. Pokud máte jiný osvědčený způsob, můžete se s
námi podlěit v diskusi. Každopádně, než se rozhodnete preferovat
některou z variant, měli byste vzít v úvahu takové věci, jako je
rychlost, čitelnost kódu, rozšiřitelnost a bezpečnost. Koneckonců,
výsledek záleží na Vás.