Zend_Feed-ConsumingRss.xml 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.feed.consuming-rss">
  5. <title>RSS フィードの使用</title>
  6. <!-- Skip-EN-Revisions: 21606, 21818 -->
  7. <para>注意:このドキュメントでは、英語版のリビジョン 21606, 21818 の更新内容をスキップしています。</para>
  8. <para>
  9. <acronym>RSS</acronym> フィードの読み込みは、フィードの <acronym>URL</acronym> を指定して
  10. <classname>Zend_Feed_Rss</classname> のインスタンスを作成するのと同じくらい簡単です。
  11. </para>
  12. <programlisting language="php"><![CDATA[
  13. $channel = new Zend_Feed_Rss('http://rss.example.com/channelName');
  14. ]]></programlisting>
  15. <para>
  16. フィードの取得時にエラーが発生した場合は
  17. <classname>Zend_Feed_Exception</classname> がスローされます。
  18. </para>
  19. <para>
  20. フィードオブジェクトを取得すると、標準的な <acronym>RSS</acronym> の "channel"
  21. プロパティに対して直接アクセスできるようになります。
  22. </para>
  23. <programlisting language="php"><![CDATA[
  24. echo $channel->title();
  25. ]]></programlisting>
  26. <para>
  27. 関数の構文に注意しましょう。"getter" 方式の構文 (<code>$obj->property</code>)
  28. をした場合は、<classname>Zend_Feed</classname> はプロパティを <acronym>XML</acronym> オブジェクトとして扱います。
  29. 一方、メソッドの構文 (<code>$obj->property()</code>)
  30. を使用した場合は文字列として扱います。
  31. これにより、特定のノードを取得したあとで、さらにその子要素にもアクセスできるようになります。
  32. </para>
  33. <para>
  34. チャネルのプロパティが属性を保持している場合、<acronym>PHP</acronym>
  35. の配列構文を使用してそれらにアクセスできます。
  36. </para>
  37. <programlisting language="php"><![CDATA[
  38. echo $channel->category['domain'];
  39. ]]></programlisting>
  40. <para>
  41. <acronym>XML</acronym> の属性は子を持つことができないので、
  42. 属性値へアクセスする際にメソッド構文を使用する必要はありません。
  43. </para>
  44. <para>
  45. たいていの場合は、フィードをループさせたうえで、
  46. 個々のエントリに対して何かをすることになるでしょう。
  47. <classname>Zend_Feed_Abstract</classname> は <acronym>PHP</acronym> の <code>Iterator</code>
  48. インターフェイスを実装しているので、
  49. 例えばチャネル内の全記事のタイトルを表示するには単にこのようにするだけです。
  50. </para>
  51. <programlisting language="php"><![CDATA[<?php
  52. foreach ($channel as $item) {
  53. echo $item->title() . "\n";
  54. }
  55. ]]></programlisting>
  56. <para>
  57. <acronym>RSS</acronym> にあまり詳しくない方のために、<acronym>RSS</acronym> チャネルおよび個々の <acronym>RSS</acronym>
  58. アイテム (エントリ) で利用できる標準的な要素をまとめます。
  59. </para>
  60. <para>
  61. 必須のチャネル要素
  62. </para>
  63. <para>
  64. <itemizedlist>
  65. <listitem>
  66. <para><code>title</code> - チャネルの名前</para>
  67. </listitem>
  68. <listitem>
  69. <para><code>link</code> - チャネルに対応するウェブサイトの <acronym>URL</acronym></para>
  70. </listitem>
  71. <listitem>
  72. <para><code>description</code> - チャネルについての説明</para>
  73. </listitem>
  74. </itemizedlist>
  75. </para>
  76. <para>
  77. よく使用されるオプションのチャネル要素
  78. </para>
  79. <para>
  80. <itemizedlist>
  81. <listitem>
  82. <para><code>pubDate</code> -
  83. コンテンツの発行日を <acronym>RFC</acronym> 822 の日付書式で表したもの</para>
  84. </listitem>
  85. <listitem>
  86. <para><code>language</code> - チャネルで使用している言語</para>
  87. </listitem>
  88. <listitem>
  89. <para><code>category</code> -
  90. チャネルの所属するカテゴリ (複数の場合は複数のタグで指定)</para>
  91. </listitem>
  92. </itemizedlist>
  93. </para>
  94. <para>
  95. <acronym>RSS</acronym> の <code>&lt;item&gt;</code> 要素には必須要素はありません。
  96. しかし <code>title</code> あるいは <code>description</code>
  97. が存在しなければなりません。
  98. </para>
  99. <para>
  100. よく使用されるアイテム要素
  101. </para>
  102. <para>
  103. <itemizedlist>
  104. <listitem>
  105. <para><code>title</code> - アイテムのタイトル</para>
  106. </listitem>
  107. <listitem>
  108. <para><code>link</code> - アイテムの <acronym>URL</acronym></para>
  109. </listitem>
  110. <listitem>
  111. <para><code>description</code> - アイテムの概要</para>
  112. </listitem>
  113. <listitem>
  114. <para><code>author</code> - 著者のメールアドレス</para>
  115. </listitem>
  116. <listitem>
  117. <para><code>category</code> - アイテムが所属するカテゴリ</para>
  118. </listitem>
  119. <listitem>
  120. <para><code>comments</code> - このアイテムに関連するコメントの <acronym>URL</acronym></para>
  121. </listitem>
  122. <listitem>
  123. <para><code>pubDate</code> - アイテムの発行日を <acronym>RFC</acronym> 822 の日付書式で表したもの</para>
  124. </listitem>
  125. </itemizedlist>
  126. </para>
  127. <para>
  128. 要素が空要素であるかどうかは、以下のようにして調べられます。
  129. </para>
  130. <programlisting language="php"><![CDATA[
  131. if ($item->propname()) {
  132. // ... 続行できます
  133. }
  134. ]]></programlisting>
  135. <para>
  136. <code>$item->propname</code> 形式を使用した場合は、
  137. 空のオブジェクトについても <constant>TRUE</constant> と評価されてしまうので、
  138. このように調べることはできません。
  139. </para>
  140. <para>
  141. 詳細な情報は、
  142. <ulink url="http://blogs.law.harvard.edu/tech/rss">http://blogs.law.harvard.edu/tech/rss</ulink>
  143. にある <acronym>RSS</acronym> 2.0 の公式仕様を参照ください。
  144. </para>
  145. </sect1>
  146. <!--
  147. vim:se ts=4 sw=4 et:
  148. -->