Zend_Feed

Introduction

Le composant Zend_Feed offre des services permettant de traiter des flux RSS et Atom. Il permet d'accéder aux éléments d'un flux, aux attributs d'un flux et aux attributs des entrées d'un flux, tout cela au moyen d'une syntaxe intuitive. Zend_Feed prend aussi complètement en charge la modification de la structure des flux et des entrées, avec la même syntaxe intuitive que précédemment, et il sait transformer le résultat en XML. À l'avenir, la prise en charge des modifications pourrait aussi inclure la prise en charge du protocole de publication Atom.

Sur le plan de la programmation, Zend_Feed est constitué d'une classe de base Zend_Feed et de classes de base abstraites Zend_Feed_Abstract et Zend_Feed_Entry_Abstract, permettant de représenter respectivement des flux et des entrées ; Zend_Feed contient aussi des implémentations particulières de ces classes abstraites pour les flux et entrées RSS et Atom ainsi qu'un assistant en coulisses qui assure le bon fonctionnement de la syntaxe intuitive.

Dans l'exemple ci-dessous, nous illustrons une utilisation simple de Zend_Feed : on obtient un flux RSS et on enregistre les portions du flux qui nous intéressent dans un tableau PHP simple, qui pourra ensuite être utilisé pour afficher les données, les stocker dans une base de données etc.

Note: Attention
Beaucoup de flux RSS ont à leur disposition différentes propriétés, pour les canaux comme pour les éléments. La spécification RSS spécifie beaucoup de propriétés optionnelles et gardez donc cela à l'esprit lorsque vous écrivez du code qui manipule des données RSS.

Example #1 Manipuler des données RSS avec Zend_Feed

  1. // on va chercher les dernières news de Slashdot
  2. try {
  3.     $rssSlashdot =
  4. Zend_Feed::import('http://rss.slashdot.org/Slashdot/slashdot');
  5. } catch (Zend_Feed_Exception $e) {
  6.     // l'importation du flux a échoué
  7.     echo "Une exception a été interceptée lors de l'importation "
  8.        . "du flux : {$e->getMessage()}\n";
  9.     exit;
  10. }
  11.  
  12. // on initialise un tableau contenant les données du canal RSS
  13. $canal = array(
  14.     'titre'       => $rssSlashdot->title(),
  15.     'lien'        => $rssSlashdot->link(),
  16.     'description' => $rssSlashdot->description(),
  17.     'elements'    => array()
  18.     );
  19.  
  20. // on itère sur chaque élément du canal et
  21. // on stocke les données qui nous intéressent
  22. foreach ($rssSlashdot as $elem) {
  23.     $canal['elements'][] = array(
  24.         'titre'       => $elem->title(),
  25.         'lien'        => $elem->link(),
  26.         'description' => $elem->description()
  27.         );
  28. }

Zend_Feed