麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > PHP > 正文

基于PHP和AJAX創(chuàng)建RSS聚合器

2024-05-04 22:53:40
字體:
來源:轉載
供稿:網友
注冊會員,創(chuàng)建你的web開發(fā)資料庫,  想象使用一個簡單html文件來把一個請求發(fā)送到一個服務器端腳本,收到一個基于該請求的定制xml文件,然后把它顯示給用戶而幾乎不需要刷新瀏覽器!本文作者將同你一起探討怎樣在普通web應用程序中聯(lián)合php和ajax技術來創(chuàng)建實時的數(shù)據傳輸而不需要進行瀏覽器刷新。

  盡管本文所使用的是php語言,但是請記住任何服務器端語言都會正常工作。為了理解本文,我假定你基本理解javascript和php或一類似服務器端語言。

  本文示例使用ajax來把一請求從一個rss饋送發(fā)送到一定制的php對象。該php對象復制一份在本地服務器上的該饋送并返回這一路徑。該請求對象收到這一路徑,分析它,并且把數(shù)據以html形式顯示給用戶。這聽起來涉及很多步驟,其實它僅由4個小文件組成。之所以使用了4個小文件,是為了平衡它們各自特定的力量而使整個系統(tǒng)的處理極富效率性。

  有些讀者可能會問,為什么你要創(chuàng)建在本地服務器上的饋送的一個副本而不是簡單分析最原始的饋送。原因是,這樣以來可以允許繞過xml http request對象所強加的跨域限制。后面,我還會解釋怎樣創(chuàng)建這個定制的php對象;但是首先,讓我們從表單創(chuàng)建開始。

  創(chuàng)建發(fā)出請求的表單

  你要做的第一事情是,在你的html的head標簽之間包括你可能想使用的javascript和任何css文件。我包括了一個式樣表來實現(xiàn)該聚合器的最后布局并用一個javascript文件來發(fā)出請求和進行饋送分析:

<link href="css/layout.css" rel="stylesheet" type="text/css" />
<script src="js/request.js"></script>
  下一步,創(chuàng)建一個表單,它針對你所選擇的一個rss饋送發(fā)出請求。我創(chuàng)建的表單只包括一個輸入字段和一個提交該請求的按鈕。該請求的查詢是一個字符串,它由饋送輸入值和一個將在服務器端被校驗的口令字組成;作為一個示例,我使用了下面形式:
"password=mypassword

  該代碼在每次頁面加載之時發(fā)出一次請求;因此,如果頁面被刷新,現(xiàn)有的在該輸入域中的饋送串將在頁面加載時被請求。下面是一個表單數(shù)據的示例,連同一些div標簽用來顯示已分析的饋送的特定結點:

<body password=mypassword');">
<form name="feedform" method="post" action="javascript:makerequest('request.php?request=' + document.feedform.feed.value + '"password=mypassword');">
enter a feed: <input type="text" name="feed" id="feed" size="20">
?。糹nput type="submit" name="submit" value="add feed">
</form>
<div id="logo"></div>
<hr/>
<div id="copy"></div>
<div id="details"></div>
</body>
  我所創(chuàng)建的這三個div標簽是logo,copy和details,其中每一個都在布局樣式表中有一個與之相關聯(lián)的樣式。當我們分析饋送時將會用到它們,但是我們首先需要能夠存取我們所請求的饋送。這可以使用我前面所提到的php對象來完成。

  創(chuàng)建定制的php對象


  我用php創(chuàng)建了一個小型rss類,它在本地服務器上創(chuàng)建一個請求饋送的副本,這樣它可以為我們稍后要創(chuàng)建的xml http request對象所存取。典型地,你不能跨域請求一個文件,這意味著你要請求的文件需要位于本地服務器上。這個類是一種解決跨域問題的辦法,因為它創(chuàng)建該饋送的一個副本,這個副本在本地服務器上被請求并且把本地路徑返回到該饋送,然后它由該request對象來存取。

  這個類中唯一的方法是一個請求方法,它僅有一個指向所請求的rss 饋送的url的參數(shù)。然后,它通過rss的名字來檢查是否一目錄位于本地服務器上。如果不存在,就創(chuàng)建一個并把其權限模式設置為0666,這意味著該目錄可讀寫。當被設置為可讀的時,該目錄就可以在以后被存??;而當被設置為可寫的時,就可以把該饋送的一個副本寫向本地服務器上的目錄:

//如果不存在目錄就創(chuàng)建一個
$dir = "rss";
if(!is_dir($dir))
{
 mkdir($dir, 0666);
}
  注意

  在一臺windows機器上,對于php 4.2.0及以上版本中模式設置是不被要求的。但是,如果它存在的話,它將被忽略;因此,我保留了它,以備該工程被遷移到一臺unix或linux服務器上。

  在把饋送復制到該服務器前,我們需要一個唯一的文件名。我對這個完整的url使用了md5加密方法以確保所有饋送的名字是唯一的。通過這個新的文件名,它可以連接一個描述指向該文件的目錄的字符串;這將在創(chuàng)建該饋送的副本時使用:

//創(chuàng)建唯一的命名
$file=md5($rss_url);
$path="$dir/$file.xml";
  通過使用被定義在上面的路徑和到原始的被請求的饋送的url的參考,現(xiàn)在我們能創(chuàng)建該文件的一個副本。最后,把該路徑返回到該新文件,作為對該請求的響應:

//復制饋送到本地服務器
copy($rss_url,"$path");
return $path;
following is the small, yet powerful rss class in its entirety:
<?php
class rss
{
 function get($rss_url)
 {
  if($rss_url != "")
  {
   //如果不存在目錄就創(chuàng)建一個
   $dir = "rss";
   if(!is_dir($dir))
   {
    mkdir($dir, 0666);
   }
   // 創(chuàng)建一個唯一的名字
   $file = md5($rss_url);
   $path = "$dir/$file.xml";
   //復制饋送到本地服務器
   copy($rss_url, "$path");
   return $path;
  }
 }
}
?>
  為了存取該php類中的方法,需要有一個請求文件來擔當?shù)皆擃惖囊粋€接口,這也正是我們正在請求的文件。這個文件首先驗證從該請求查詢的一口令變量,或者返回一條指定該請求者不是一名經授權的用戶的消息,或者用指向rss饋送(該饋送在由請求方法處理后被復制到本地服務器)的路徑作出響應。為了響應該rss饋送,需要包含這個rss對象并把它實例化,并且需要通過使用被請求的饋送的url作為一參數(shù)來激活請求方法:

<?
if($password == "mypassword")
{
 require_once('classes/rss.class.php');
 $rss = new rss();
 echo $rss->get($request);
}
else
{
 echo "you are an unauthorized user";
}
?>
  get/post與ajax相結合

  為了post請求,我們首先需要創(chuàng)建該請求對象。如果你沒有創(chuàng)建請求對象的經驗,那么可以讀一下我的文章《how to use ajax》或簡單地研究一下本文的示例源代碼。一旦創(chuàng)建該請求對象,就可以調用sendfeed方法并傳遞由表單所創(chuàng)建的url:

function sendfeed(url){
 post.onreadystatechange = sendrequest;
 post.open("post", url, true);
 post.send(url);
}
  一旦收到來自于php對象的響應并被正確加載,則對與該響應相應的本地文件發(fā)出另一個請求。在這種情況中,post.responsetext提供給我們該新文件的路徑:

function sendrequest(){
 if(checkreadystate(post)){
  request = createrequestobject();
  request.onreadystatechange = onresponse;
  request.open("get", post.responsetext, true);
  request.send(null);
 }
}
  分析響應

  由于rss饋送之間的區(qū)別,分析響應具有一定的挑戰(zhàn)性。一些含有包含標題和描述結點的圖像,而其它則沒有。因此,當我們分析回饋時,我們需要做一點檢查來譯解它是否包括一圖像。如果它包括一圖像,我們就可以,與該饋送的標題和鏈接一起,在image div標簽中顯示該圖像:

var _logo = "";
var _title = response.getelementsbytagname('title')[0].firstchild.data;
var _link = response.getelementsbytagname('link')[0].firstchild.data;;
_logo += "<a href='" + _link + "' target='_blank'>" + _title + "</a><br/>";
if(checkfortag(response.getelementsbytagname('image')[0]))
{
 var _url = response.getelementsbytagname('url')[0].firstchild.data;
 _logo += "<img src='" + _url + "' border='0'><br/>"
}
document.getelementbyid('logo').innerhtml = _logo;
  我們不僅必須檢查每個圖像以顯示它,當遍歷饋送中所有的項時我們還需要對之進行檢查。因為如果存在一個圖像,那么所有另外的標題和鏈接結點索引都將無法正常工作。因此,當發(fā)現(xiàn)圖像標簽時,我們應該通過在每一次遍歷中增加索引值(+1)來調整標題和鏈接結點的索引:

if(checkfortag(response.getelementsbytagname('image')[0]) "" i>0){
 var _title=response.getelementsbytagname('title')[i+1].firstchild.data;
 var _link=response.getelementsbytagname('link')[i+1].firstchild.data;
}
else{
 var _title =response.getelementsbytagname('title')[i].firstchild.data;
 var _link = response.getelementsbytagname('link')[i].firstchild.data;
}

  你可以使用checkfortag方法來檢查是否存在特定的標簽:

function checkfortag(tag){
 if(tag != undefined) {
  return true;
 }
 else{
  return false;
 }
}
  存在許多種進行饋送分析的可能性。例如,你可以把項賦到類別上并使得該類別可折迭,這樣用戶就可以對其想觀看的內容進行選擇。作為一個示例,我使用日期來對項進行分類-這可以通過譯解是否針對一個特定項的pubdate不同于前一個項的pubdate并且相應地顯示一新的日期來實現(xiàn):

if(i>1){
 var previouspubdate = response.getelementsbytagname('pubdate')[i-1].firstchild.data;
}
if(pubdate != previouspubdate || previouspubdate == undefined){
 _copy += "<div id='detail'>" + pubdate + "</div><hr align='left' width='90%'/>";
}
_copy += "<a href=/"javascript:showdetails('" + i + "');/">" + _title + "</a><br/><br/>";
document.getelementbyid('copy').innerhtml += _copy;
  注意,上面的最后一部分是showdetails方法,它用于當一用戶從一個饋送中選擇一特定的項時進行細節(jié)顯示。這個方法有一個參數(shù)(項索引值),這個索引用于發(fā)現(xiàn)在該饋送中details結點的索引:

function showdetails(index){
 document.getelementbyid('details').innerhtml = response.getelementsbytagname('description')[index].firstchild.data;
}
  結論

  使用ajax發(fā)送查詢字符串到一個服務器端腳本并檢索一個基于該串的定制響應,這對于任何者都有實現(xiàn)的可能。這樣以來,你的下一個web應用程序也將會充滿了新的可能性。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲第一成av人网站懂色 | 麻豆视频免费网站 | 免费看黄色三级毛片 | 免费在线观看毛片视频 | chinesegv男男猛男无套 | 斗罗破苍穹在线观看免费完整观看 | 逼片| 一级免费在线 | 一本一本久久a久久精品综合小说 | 狠狠操夜夜爱 | 欧美成人一区免费视频 | 精品国产91一区二区三区 | 精品一区二区电影 | 日本高清在线免费 | 欧美视频一区二区三区在线观看 | 欧美a久久 | 永久免费不卡在线观看黄网站 | 免费观看高清视频网站 | 欧美特级一级毛片 | 亚洲欧美日韩久久精品第一区 | 欧美一区在线观看视频 | 麻豆传传媒久久久爱 | 成人国产精品久久久 | 羞羞的视频在线观看 | 黄色大片在线免费看 | 久久国产成人午夜av浪潮 | 永久免费不卡在线观看黄网站 | 色网站免费观看 | 国产一区二区三区四区在线 | 草操视频 | 亚洲人成中文字幕在线观看 | 欧美黑人伦理 | 91精选视频在线观看 | 亚洲成人在线视频网站 | 在线视频1区 | 九九热九九热 | 羞羞答答tv| 欧美综合在线观看视频 | 久久国产免费 | 热re91久久精品国产99热 | 成年性羞羞视频免费观看 |