Avec le développement d'Internet, le RSS est devenu un moyen populaire de s'abonner à des informations. La fonction d'abonnement RSS peut être facilement implémentée à l'aide de PHP, permettant aux utilisateurs d'obtenir plus facilement les dernières informations.
1. Créer une table de base de données
Avant d'implémenter la fonction d'abonnement RSS, vous devez créer une table dans la base de données pour stocker les informations sur la source RSS souscrites par les utilisateurs. Le formulaire contient quatre champs : ID, URL, titre et description. La structure spécifique est la suivante :
CREATE TABLE `feed` ( `id` int(11) NOT NULL AUTO_INCREMENT, `url` varchar(255) NOT NULL, `title` varchar(255) NOT NULL, `description` varchar(255) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2. Écrivez le code d'abonnement
Ensuite, nous devons écrire du code PHP pour implémenter les fonctions d'abonnement utilisateur et d'affichage de Contenu RSS. Tout d'abord, nous définissons une classe RSS pour obtenir et analyser les fichiers XML :
class RSS { private $url; public function __construct($url) { $this->url = $url; } public function get_feed() { $xml = simplexml_load_file($this->url); $feed = array( 'title' => (string) $xml->channel->title, 'description' => (string) $xml->channel->description, 'items' => array(), ); foreach($xml->channel->item as $item) { $feed['items'][] = array( 'title' => (string) $item->title, 'description' => (string) $item->description, 'link' => (string) $item->link, 'date' => (string) $item->pubDate, ); } return $feed; } }
Dans cette classe, nous utilisons la fonction simplexml_load_file pour charger le fichier XML et analyser le titre, la description et la liste des articles. Sur la page d'abonnement, nous pouvons instancier cette classe en fonction de l'URL d'abonnement et appeler la méthode get_feed pour obtenir le contenu RSS.
require_once('RSS.class.php'); // 获取订阅的 ID $id = $_GET['id']; // 连接数据库 $mysqli = new mysqli('localhost', 'user', 'password', 'dbname'); // 获取订阅的 URL $res = $mysqli->query("SELECT url FROM feed WHERE id = $id"); $url = $res->fetch_assoc()['url']; // 实例化 RSS 类 $rss = new RSS($url); // 获取 RSS 内容 $feed = $rss->get_feed(); // 显示 RSS 内容 foreach($feed['items'] as $item) { echo '<p>'; echo '<a href="' . $item['link'] . '">' . $item['title'] . '</a><br>'; echo $item['description'] . '<br>'; echo $item['date']; echo '</p>'; }
Dans ce code, nous obtenons d'abord la valeur de l'ID d'abonnement à partir du paramètre URL, puis nous nous connectons à la base de données et interrogeons l'URL correspondante. Ensuite, nous instancions la classe RSS en fonction de l'URL et appelons la méthode get_feed pour obtenir le contenu RSS. Enfin, nous parcourons et imprimons le titre, la description, le lien et l’heure de publication de chaque article.
3. Ajouter des flux
Pour que les utilisateurs puissent ajouter des flux, nous devons également écrire une page pour ajouter de nouveaux flux RSS. La page contient un formulaire qui permet aux utilisateurs de saisir l'URL, le titre et la description de l'abonnement, puis d'insérer ces informations dans la base de données :
if(isset($_POST['url'])) { $url = $_POST['url']; $title = $_POST['title']; $description = $_POST['description']; // 连接数据库 $mysqli = new mysqli('localhost', 'user', 'password', 'dbname'); // 插入订阅信息 $mysqli->query("INSERT INTO feed (url, title, description) VALUES ('$url', '$title', '$description')"); echo '添加成功!'; }
IV. Résumé
Grâce à l'implémentation du code PHP ci-dessus, nous avons implémenté avec succès le code PHP de base. Fonction d'abonnement RSS. Les utilisateurs peuvent ajouter plusieurs flux RSS et obtenir le dernier contenu des articles via la page d'abonnement. Dans le même temps, grâce à une conception simple de base de données, nous pouvons simplement interroger, ajouter et supprimer des flux pour mieux répondre aux besoins des utilisateurs.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!