1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
|
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.feed.introduction">
<title>Einführung</title>
<para>
<classname>Zend_Feed</classname> stellt Funktionalitäten für das Konsumieren von
<acronym>RSS</acronym> und Atom Feeds. Es stellt eine natürliche Syntax bereit, um auf
Elemente und Attribute des Feeds sowie auf die Attribute der Einträge zugreifen zu können.
Mit derselben natürlichen Syntax bietet <classname>Zend_Feed</classname> auch eine
umfassende Unterstützung für das Ändern von Feed und Eintragsstruktur sowie die Rückgabe der
Ergebniss nach <acronym>XML</acronym>. In Zukunft könnte diese Modifizierungsunterstützung
auch das Atom Publishing Protocol unterstützen.
</para>
<para>
<classname>Zend_Feed</classname> besteht aus der Basisklasse
<classname>Zend_Feed</classname>, sowie den beiden abstrakten Basisklassen
<classname>Zend_Feed_Abstract</classname> und
<classname>Zend_Feed_Entry_Abstract</classname> für die Darstellung von Feeds und Einträgen,
aus speziellen Implementationen von Feeds und Einträgen für <acronym>RSS</acronym> und Atom
sowie einem Helfer, der hinter den Kulissen die natürliche Syntax ermöglicht.
</para>
<para>
Im Beispiel unten demonstrieren wir einen einfachen Anwendungsfall für die Abfrage eines
<acronym>RSS</acronym> Feeds und die Speicherung relevanter Teile der Feed Daten in einem
einfachen <acronym>PHP</acronym> Array, welches dann für die Ausgabe der Daten, das
Speichern in eine Datenbank, usw. genutzt werden kann.
</para>
<note>
<title>Achtung</title>
<para>
Viele <acronym>RSS</acronym> Feeds bieten verschiedene Eigenschaften für Kanäle und
Einträge. Die <acronym>RSS</acronym> Spezifikation bietet viele optionale Eigenschaften,
also sei dir dessen beim Schreiben von Code für die Verarbeitung von
<acronym>RSS</acronym> Daten bewußt.
</para>
</note>
<example id="zend.feed.introduction.example.rss">
<title>Zend_Feed für die Verarbeitung von RSS Feed Daten verwenden</title>
<programlisting language="php"><![CDATA[
// hole die neuesten Slashdot Schlagzeilen
try {
$slashdotRss =
Zend_Feed::import('http://rss.slashdot.org/Slashdot/slashdot');
} catch (Zend_Feed_Exception $e) {
// Import des Feeds ist fehlgeschlagen
echo "Exception caught importing feed: {$e->getMessage()}\n";
exit;
}
// Initialisiere das Array mit den Channel Daten
$channel = array(
'title' => $slashdotRss->title(),
'link' => $slashdotRss->link(),
'description' => $slashdotRss->description(),
'items' => array()
);
// Durchlauf jeden Eintrag und speichere die relevanten Daten
foreach ($slashdotRss as $item) {
$channel['items'][] = array(
'title' => $item->title(),
'link' => $item->link(),
'description' => $item->description()
);
}
]]></programlisting>
</example>
</sect1>
|