Zend_Feed-Introduction.xml 3.0 KB

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