第 6 章 Zend_Feed

目录

6.1. 介绍
6.2. 用Zend_Feed来导入Feed
6.3. 从网页上获得Feed
6.4. RSS Feed的使用
6.5. Atom Feed的使用
6.6. 单个Atom记录(entry)的处理
6.7. 修改Feed和记录(entry)结构
6.8. 自定义Feed和记录(entry)类

6.1. 介绍

Zend_Feed提供了处理的 RSS 和 Atom Feed的功能。它提供了一套自然的方法用于 访问Feed元素、属性、和记录(entry)属性。 除此之外Zend_Feed还扩展提供了同样简单的方法 用于修改Feed和记录(entry)的结构,并将结果转化成XML格式。不久的将来这些扩展可能会被 Atom Publishig Protocol(AtomPP)所支持。

Zend_Feed由一个Zend_Feed基类、一个Zend_Feed_Abstract抽象类以及一个用于表示Feed和记录(entry)的Zend_Feed_EntryAbstract基类组成。这些类封装了 RSS 和 Atom 的Feed和记录(entry)特性的,提供了一套自然的方法使他们用起来变得异常简单。

在下面的例子中,我们演示了一个获得RSS Feed并将其中的一般部分相关数据保存到一个PHP数组中的简单实例,这样这些数据就能方便的用于输出或保存到数据库等。

[注意] 注意
许多RSS中的channel和item属性是不同的。RSS的规范中提供了许多可选的属性,因此在编写RSS相关应用代码时要充分考虑这点。

例 6.1. 用Zend_Feed来处理RSS Feed数据

<?php
require_once 'Zend/Feed.php';

// 取得最新的 Slashdot 头条新闻
try {
    $slashdotRss = Zend_Feed::import('http://rss.slashdot.org/Slashdot/slashdot');
} catch (Zend_Feed_Exception $e) {
    // Feed 导入失败
    echo "Exception caught importing feed: {$e->getMessage()}\n";
    exit;
}

// 初始化保存 channel 数据的数组
$channel = array(
    'title'       => $slashdotRss->title(),
    'link'        => $slashdotRss->link(),
    'description' => $slashdotRss->description(),
    'items'       => array()
    );

// 循环获得channel的item并存储到相关数组中
foreach ($slashdotRss as $item) {
    $channel['items'][] = array(
        'title'       => $item->title(),
        'link'        => $item->link(),
        'description' => $item->description()
        );
}

?>