PHPとAJAX RSS リーダー

RSSリーダーはRSS Feedを読むために使用されます。

RSSはニュースや更新を素早く閲覧するために使用されます。

AJAX RSS リーダー

以下のAJAXの例では、RSSの内容がリフレッシュせずにウェブページに読み込まれるRSSリーダーを示します。

以下のリストボックスからRSSニュースサブスクリプションを選んでください。

RSS Feedを選んでください:

ここにRSS Feedをリストアップします。

この例では、以下の3つの要素が含まれています:

  • シンプルなHTMLフォーム
  • JavaScript
  • PHP ページ

HTMLフォーム

これはHTMLページです。それにはシンプルなHTMLフォームとJavaScriptファイルを実行するリンクが含まれています:

<html>
<head>
<script type="text/javascript" src="getrss.js"></script>
</head>
<body>
<form> 
Select an RSS-Feed:
<select onchange="showRSS(this.value)">
<option value="Google">Google News</option>
<option value="MSNBC">MSNBC News</option>
</select>
</form>
<p><div id="rssOutput">
<b>RSS Feed will be listed here.</b></div></p>
</body>
</html>

例解 - HTML フォーム

ご覧の通り、上の HTML ページには、シンプルな HTML フォームが含まれており、ドロップダウンリストがあります。

フォームの動作:

  1. ユーザーがドロップダウンリストのオプションを選択すると、イベントがトリガーされます
  2. イベントがトリガーされたときに、showRSS() 関数を実行します

フォームの下には、"rssOutput" という名前の <div> があります。それは showRSS() 関数が返すデータのプレースホルダーとして使用されます。

JavaScript

JavaScript コードは "getrss.js" に保存されており、HTML ドキュメントにリンクされています:

var xmlHttp
function showRSS(str)
 { 
 xmlHttp=GetXmlHttpObject()
 if (xmlHttp==null)
  {
  alert ("ブラウザは HTTP リクエストをサポートしていません")
  return
  }
 var url="getrss.php"
 url=url+"?q="+str
 url=url+"&sid="+Math.random()
 xmlHttp.onreadystatechange=stateChanged 
 xmlHttp.open("GET",url,true)
 xmlHttp.send(null)
 }
function stateChanged() 
 { 
 if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
  { 
  document.getElementById("rssOutput")
  .innerHTML=xmlHttp.responseText 
  } 
 }
function GetXmlHttpObject()
{
var xmlHttp=null;
try
 {
 // ファイアフォックス、オペラ 8.0+、サファリ
 xmlHttp=new XMLHttpRequest();
 }
catch (e)
 {
 // インターネットエクスプローラー
 try
  {
  xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
  }
 catch (e)
  {
  xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
 }
return xmlHttp;
}

例説明:

stateChanged() と GetXmlHttpObject 関数と PHPとAJAXリクエスト このセクションの例は同じです。

showRSS() 関数

ドロップダウンリストで選択が行われるたびに、この関数が実行されます:

  1. サーバーに送信する URL(ファイル名)を定義します
  2. パラメータ (q) を URL に追加し、パラメータの内容はドロップダウンリストの選択されたオプションです
  3. ランダムな数を追加して、サーバーがファイルをキャッシュしないようにします
  4. GetXmlHttpObject 関数を呼び出して XMLHTTP オブジェクトを作成し、そのオブジェクトが状態が変更されたときに stateChanged 関数を実行するように指示します
  5. 指定された URL を開くために XMLHTTP
  6. HTTP リクエストをサーバーに送信します

PHP ページ

JavaScript コードを呼び出すサーバーページは、"getrss.php"という名前の PHP ファイルです:

<?php
//get the q parameter from URL
$q=$_GET["q"];
//find out which feed was selected
if($q=="Google")
 {
 $xml=("http://news.google.com/news?ned=us&topic=h&output=rss");
 }
elseif($q=="MSNBC")
 {
 $xml=("http://rss.msnbc.msn.com/id/3032091/device/rss/rss.xml");
 }
$xmlDoc = new DOMDocument();
$xmlDoc->load($xml);
//get elements from "<channel>"
$channel=$xmlDoc->getElementsByTagName('channel')->item(0);
$channel_title = $channel->getElementsByTagName('title')
->item(0)->childNodes->item(0)->nodeValue;
$channel_link = $channel->getElementsByTagName('link')
->item(0)->childNodes->item(0)->nodeValue;
$channel_desc = $channel->getElementsByTagName('description')
->item(0)->childNodes->item(0)->nodeValue;
//output elements from "<channel>"
echo("<p><a href='" . $channel_link
 . "'>" . $channel_title . "</a>");
echo("<br />");
echo($channel_desc . "</p>");
//get and output "<item>" elements
$x=$xmlDoc->getElementsByTagName('item');
for ($i=0; $i<=2; $i++)
 {
 $item_title=$x->item($i)->getElementsByTagName('title')
 ->item(0)->childNodes->item(0)->nodeValue;
 $item_link=$x->item($i)->getElementsByTagName('link')
 ->item(0)->childNodes->item(0)->nodeValue;
 $item_desc=$x->item($i)->getElementsByTagName('description')
 ->item(0)->childNodes->item(0)->nodeValue;
 echo ("<p><a href='" . $item_link
 . "'>" . $item_title . "</a>");
 echo ("<br />");
 echo ($item_desc . "</p>");
 }
?>

例説明:

オプションが JavaScript から送信された場合、以下が発生します:

  1. PHP がどの RSS フィードが選択されたかを検出します
  2. 選択された RSS フィード用に XML DOM オブジェクトを作成します
  3. RSS フィードからの要素を検出し、出力します
  4. 前三个 RSS プロジェクトの要素を遍历し、出力します