1 <sect1 id="zend.feed.consuming-rss">
2 <title>Odbieranie danych z kanału informacyjnego RSS</title>
4 Odczytywanie kanału RSS jest tak proste jak utworzenie obiektu <code>Zend_Feed_Rss</code> z adresem
5 URL kanału przekazanym do konstruktora:
7 <programlisting role="php"><![CDATA[
8 $channel = new Zend_Feed_Rss('http://rss.example.com/channelName');
12 Jeśli wystąpi jakiś błąd podczas obróbki danych pochodzących z kanału,
13 zostanie wyrzucony wyjątek <code>Zend_Feed_Exception</code>.
17 Kiedy już masz obiekt kanału informacyjnego, możesz łatwo uzyskać dostęp
18 do standardowych właściwości kanału RSS bezpośrednio na obiekcie:
20 <programlisting role="php"><![CDATA[
21 echo $channel->title();
25 Zwróć uwagę na składnie funkcji. <code>Zend_Feed</code> używa konwencji
26 traktującej właściwości jak obiekt XML gdy próbujemy uzyskać do nich dostęp
27 za pomocą składni "getter" (<code>$obj->property</code>) i jako łańcuch
28 znaków gdy próbujemy uzyskać dostęp jak do metody (<code>$obj->property()</code>).
29 To pozwala na pełny dostęp do danych tekstowych przy jednoczesnym dostępie
30 do wszystkich niższych składników.
34 Jeśli właściwości kanału mają atrybuty, są one dostępne przy użyciu składni
37 <programlisting role="php"><![CDATA[
38 echo $channel->category['domain'];
42 Since XML attributes cannot have children, method syntax is not necessary for accessing attribute
47 Najczęściej będziesz chciał przejść pętlą po danych kanału i zrobić coś
48 z jego wpisami. Klasa <code>Zend_Feed_Abstract</code> implementuje wbudowany
49 w PHP interfejs <code>Iterator</code>, więc wyświetlenie wszystkich tytułów
50 artykułów z kanału jest bardzo proste:
52 <programlisting role="php"><![CDATA[
53 foreach ($channel as $item) {
54 echo $item->title() . "\n";
59 Jeśli nie jesteś obeznany z RSS, poniżej znajdziesz opis podstawowych
60 składników, które możesz znaleść w kanale RSS i w jego indywidualnych
65 Wymagane składniki kanału:
71 <para><code>title</code> - Nazwa kanału</para>
74 <para><code>link</code> - Adres URL strony internetowej odpowiadającej kanałowi</para>
77 <para><code>description</code> - Opis kanału</para>
83 Opcjonalne składniki kanału:
89 <para><code>pubDate</code> - Data publikacji zawartości, format RFC 822 format</para>
92 <para><code>language</code> - Język kanału</para>
95 <para><code>category</code> - Jedna lub więcej kategorii do których należy kanał</para>
101 Elementy RSS <code><item></code> nie mają wymaganych składników,
102 jednak albo składnik <code>title</code> albo <code>description</code> musi
107 Składniki elementu kanału:
113 <para><code>title</code> - Tytuł elementu</para>
116 <para><code>link</code> - Adres URL elementu</para>
119 <para><code>description</code> - Opis elementu</para>
122 <para><code>author</code> - Adres email autora elementu</para>
125 <para><code>category</code> - Jedna lub więcej kategorii do których należy element</para>
128 <para><code>comments</code> - Adres URL komentarzy do tego elementu</para>
131 <para><code>pubDate</code> - Data publikacji elementu, w formacie RFC 822</para>
137 W twoim kodzie zawsze możesz sprawdzić czy element nie jest pusty za pomocą:
139 <programlisting role="php"><![CDATA[
140 if ($item->propname()) {
147 Jeśli zamiast tego użyjesz <code>$item->propname</code>, zawsze dostaniesz
148 pusty obiekt który zostanie skonwertowany do wartości <code>TRUE</code>,
153 Więcej informacji dostępnych jest w oficjalnej specyfikacji RSS 2.0:
154 <ulink url="http://blogs.law.harvard.edu/tech/rss">http://blogs.law.harvard.edu/tech/rss</ulink>