Forum » » Le coin des codeurs » » mettre un fil RSS dans un bloc
Posté : 23 févr. 2012 à 14:30
<?php
// --------------------------------------------------------
// d'après parse_flux-2 pour lire des fichiers RSS/RDF/Atom
// Dominique WOJYLAC < <a href=" <a href="http://wojylac.free.fr>"" target="_blank" class="noir">http://wojylac.free.fr>"</a> target="_blank" class="noir"> <a href="http://wojylac.free.fr></a>" target="_blank" class="noir">http://wojylac.free.fr></a></a>
// Distribué sous GNU General Public License.
//
// Version 2.1c
// ---------------------------------------------------------
// fonction destinée à nettoyer le texte récupéré
// que l'on pourrait séparer de ce code en la mettant dans un fichier à inclure
function clean_text($text, $encodage = '') {
if ($encodage == 'utf-8') {
$text = utf8_decode($text);
}
$avant = array(
'<',
'>',
'"',
'&',
'|@|' // pour traitement correct des caractères spéciaux préalablement remplacés (voir plus bas)
);
$apres = array(
'<',
'>',
'"',
'&',
'&#'
);
$text = str_replace($avant, $apres, $text);
return $text;
}
function lit_RSS($flux,$delai,$nbnews,$affichage) {
!include!_once 'rss_read.inc.php';
$rss = new rss_read();
// il est considéré comme n'étant pas en cache on le génére
$data = '';
// caractères parasites pouvant être contenus dans le fils rss et à remplacer par d'autres
// doit être invoqué avant parsefile
// cette fonction est optionnelle et ne doit être utilisée que pour certains fils.
$avant = array('&#','•');
$apres = array('|@|','-');
$rss -> to_replace_with($avant, $apres);
// parser le fichier news
$res = $rss -> parsefile($flux);
if ($res) {
$encode = $rss -> get_encoding();
// recupération des données sur le channel
$channel = $rss -> get_channel();
// affichage site, url, description
$data = '<p class='flux-RSS'><a href="'. $channel['link'].'" target="_blank">'. clean_text($channel['title'], $encode). ' - RSS fead</a></p>';
// nombre d'items
//$nbnews = $rss -> get_num_items();
// recup array des données
$items = $rss -> get_items();
$data .= '<dl class='flux-RSS'>';
for($i = 0; $i < $nbnews; $i++) {
if ($affichage == '1') {
$data .= '<dt>- '.clean_text($items[$i]['link'], $encode).'</dt>'."\n";
} else {
$data .= '<dt>- <a href="'.$items[$i]['link'].'" target="_blank">'.clean_text($items[$i]['title'], $encode).'</a></dt>'."\n";
}
}
$data .= '</dl>';
} // fin if $rss
return $data;
}
$content = "";
$content .= lit_RSS(' <a href=" <a href="http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1');"" target="_blank" class="noir">http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1');"</a> target="_blank" class="noir"> <a href="http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1');</a>" target="_blank" class="noir">http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1');</a></a>
//echo $content; // débug
?>
!include!#modules/fil_le/lecteurRSS.php
if (file_exists("./modules/fil_le/lecteurRSS.php")) !include!_once("./modules/fil_le/lecteurRSS.php");
<?php
// --------------------------------------------------------
// d'après parse_flux-2 pour lire des fichiers RSS/RDF/Atom
// Dominique WOJYLAC < <a href=" <a href="http://wojylac.free.fr>"" target="_blank" class="noir">http://wojylac.free.fr>"</a> target="_blank" class="noir"> <a href="http://wojylac.free.fr></a>" target="_blank" class="noir">http://wojylac.free.fr></a></a>
// Distribué sous GNU General Public License.
//
// Version 2.1c
// ---------------------------------------------------------
// fonction destinée à nettoyer le texte récupéré
// que l'on pourrait séparer de ce code en la mettant dans un fichier à inclure
function clean_text($text, $encodage = '') {
if ($encodage == 'utf-8') {
$text = utf8_decode($text);
}
$avant = array(
'<',
'>',
'"',
'&',
'|@|' // pour traitement correct des caractères spéciaux préalablement remplacés (voir plus bas)
);
$apres = array(
'<',
'>',
'"',
'&',
'&#'
);
$text = str_replace($avant, $apres, $text);
return $text;
}
function lit_RSS($flux,$delai,$nbnews,$affichage) {
!include!_once 'rss_read.inc.php';
$rss = new rss_read();
// il est considéré comme n'étant pas en cache on le génére
$content = '';
// caractères parasites pouvant être contenus dans le fils rss et à remplacer par d'autres
// doit être invoqué avant parsefile
// cette fonction est optionnelle et ne doit être utilisée que pour certains fils.
$avant = array('&#','•');
$apres = array('|@|','-');
$rss -> to_replace_with($avant, $apres);
// parser le fichier news
$res = $rss -> parsefile($flux);
if ($res) {
$encode = $rss -> get_encoding();
// recupération des données sur le channel
$channel = $rss -> get_channel();
// affichage site, url, description
$content = '<p class='flux-RSS'><a href="'. $channel['link'].'" target="_blank">'. clean_text($channel['title'], $encode). ' - RSS fead</a></p>';
// nombre d'items
//$nbnews = $rss -> get_num_items();
// recup array des données
$items = $rss -> get_items();
$content .= '<dl class='flux-RSS'>';
for($i = 0; $i < $nbnews; $i++) {
if ($affichage == '1') {
$content .= '<dt>- '.clean_text($items[$i]['link'], $encode).'</dt>'."\n";
} else {
$content .= '<dt>- <a href="'.$items[$i]['link'].'" target="_blank">'.clean_text($items[$i]['title'], $encode).'</a></dt>'."\n";
}
}
$content .= '</dl>';
} // fin if $rss
return $content;
}
?>
function#lit_RSS
params#' <a href=" <a href="http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1'"" target="_blank" class="noir">http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1'"</a> target="_blank" class="noir"> <a href="http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1'</a>" target="_blank" class="noir">http://www.pedigreedatabase.com/german_shepherd_dog/rss.classified_latest','600','5','1'</a></a>
Message édité par : PhilGuen / 23-02-2012 14:39
Cet article provient de NPDS
https://www.npds.org/viewtopic.php?topic=25384&forum=5