如何用PHP把RDF内容插入Web站点之中(6)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 
echo "<li><a href=" . $item["link"] . ">" .
$item["title"] . "</a>",
}
}
?>
</ul>

每次你重新装入上面的脚本,相应的RDF文件就会被从特定的位置上取来,经过分析之后,按要求的格式显示出来。
如果你站点具有高的访问量,你就可能觉得我们的辛苦无意义之极,尤其是当所用的RDF数据更新地没有那么快时,情况更糟。 在这种情况下,或许探究一下在本地缓存RDF数据才是较明智的做法:要么扩展上面的例子程序,在其中加入缓存功能;要么每阁几个小时都花很长的时间下载一个最新RDF文件的本地副本到你的Web服务器上,然后使用这个本地副本,而不是那个“活”的(the “live” one)。

8)免费午餐(A Free Lunch)
上面我所写的那个类也是很基本的,是拿来说明问题的,或许也可以用于低访问量的站点。如果你想寻找一些更专业的东西,去网上吧,那里有许多的开放源码的RDF分析器,他们带有各种附加的功能(包括缓存)。 那么就让我们看一些如何运用这些分析器的例子吧。
第一个要讲的是由Stefan Saasen 为fase4网站开发的RDF分析器类,可以从http://www.fase4.com/rdf/上免费下载。这是一个功能非常齐全的RDF分析器,支持缓存和通过代理认证。下面是如何使用它的例子:
<html>
<head>
<style type="text/css">
body {font-family: Verdana, font-size: 11px,}
.fase4_rdf {font-size: 13px, font-family: Verdana} .fase4_rdf_title
{font-size: 13px, font-weight : bolder,}
</style>
</head>
<body>
<?
// include class
include("rdf.class.php"),

// instantiate object
$rdf = new fase4_rdf,

// set number of items to display
$rdf->set_max_item(5),

// set RDF engine options
$rdf->use_dynamic_display(true),
$rdf->set_Options( array("image"=>"hidden", "textinput"=>"hidden") ),

// parse and display data
$rdf->parse_RDF("http://www.freshmeat.net/backend/fm-releases.rdf"),
$rdf->finish(),
?>
</body>
</html>

另一个要介绍的是由Jason Williams开发的PHP RDF分析器,可以在http://www.nerdzine.net/php_rdf/下载。这是一个未经任何任何渲染的PHP类,实现了一些基本的方法。但是它包含的大量的属性,可以让你用来安排经过处理的数据,直到你满意为止。

<html>
<head>
<basefont face="Verdana">
</head>
<body link="Red" vlink="Red" alink="Red">
<?
include("rdf_class.php"),

// this needs to be a local file
$f = new rdfFile("./fm-releases.rdf"),
$f->parse(True),
$f->ReturnTable(True, "black", "white", "100%"),
?>
</body>
</html>
关于这些类的文档在他们各自的网站上都有介绍。

9)增加一点样式(Adding A Little Style)

万一你讨厌遍历那些PHP数组并把他们用HTML标记出来的方式,那么你也可以选择通过使用XSLT样式单来格式化和显示这些数据。PHP4 .1可以通过新的XSLT API来支持Sablotron XSLT处理器,新的API可以用来合并一个XSLT样式单和一个XML文档(在这里,即RDF文件),从而非常容易的把XML标记转化为浏览器可读的HTML标记。
我不想在这上面讲的太细,你可以看一下PHP 手册,或者关注一下本文后面的链接以获得更加详细的信息。不过我还是会给出一个简单的例子来说明这个问题。首先,给出样式单文件:
<?xml version="1.0"?>

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:rss="http://purl.org/rss/1.0/"
xmlns:dc="http://purl.org/dc/elements/1.1/" version="1.0">

<!-- main page -->
<xsl:template match="/rdf:RDF">
<html>
<head>
<basefont face="Arial" size="2"/>
</head>
<body>
<xsl:apply-templates select="rss:channel" />
<ul>
<xsl:apply-templates select="rss:item" />
</ul>
</body>
</html>
</xsl:template>

<!-- channel -->
<xsl:template match="rss:channel">
<b>
<a>
<xsl:attribute name="href"><xsl:value-of select="rss:link"
/></xsl:attribute>
<xsl:value-of select="rss:title" />
</a>
</b>
</xsl:template>

<!-- item -->
<xsl:template match="rss:item">
<li />
<a>
<xsl:attribute name="href"><xsl:value-of select="rss:link"
/></xsl:attribute>
<xsl:value-of select="rss:title" />
</a>
<br />
<xsl:value-of select="rss:description" />
</xsl:template>

</xsl:stylesheet>
下面是PHP脚本,用来把上面的样式单和讲的“鲜肉”RDF文档合并起来,生成一个HTML页面:
<?php
// XML file
// this needs to be a local file
$xml = "fm-releases.rdf",

// XSLT file
$xslt = "fm.xsl",

// create a new XSLT processor
$xp = xslt_create(),

// transform the XML file as per the XSLT stylesheet
// return the result to $result
$result = xslt_process($xp, $xml, $xslt),
if ($result)
{
// print it
echo $result,
}

// clean up
xslt_free($xp),

?>
我想这相当简单,无须再加说明。两个文档合并在一起,产生了下面的“合成物”:

这是把RDF数据转换成浏览器可读的HTML的另一种方法,或许简单一些(尽管并不是最理想的)。不过要注意一点,你需要运行一个外部程序来定期更新你的RDF文件的本地副本,原因在于PHP XSLT处理器访问远端文件可能有困难。

10)家庭作业(Homework)

如果你有兴趣对这些文中谈到的和没谈到的技术了解的更多,你可以考虑访问下面的链接:
RSS 1.0 规范:
http://www.purl.org/rss/1.0/
RSS 发展史:
http://backend.userland.com/stories/rss091

W3C 网站关于RDF的内容:
http://www.w3.org/RDF/

PHP中关于SAX和DOM编程的讨论:http://www.devshed.com/Server_Side/XML/XMLwithPHP

用PHP实现XSLT转换的讨论:
http://www.devshed.com/Server_Side/XML/XSLTrans

关于PHP类的讨论:
http://www.devshed.com/Server_Side/PHP/BackToClass

时间: 2024-10-23 14:32:09

如何用PHP把RDF内容插入Web站点之中(6)的相关文章

如何用PHP把RDF内容插入Web站点之中(一)

web|插入|站点 名誉和巨大的财富 设想一个从最热门的门户网站获得最新的新闻的站点.股票价格,天气信息,新闻故事,线式讨论组,软件发布--所有这一切都将被动态更新,每小时一次,不需要任何手工干预.我们可以想象这随之而来的站点访问量,源源不断的广告收入以及网管大人所受到的"阿谀奉承". 但是现在,停止幻想,开始阅读,因为只要你密切关注此项技术,说不定你就能成为站点的主人. 对你的要求也只是稍许的想象力,一些聪明的PHP编码和几个免费的RSS文件.另外,很明显还包括这篇文章剩下的九个部分

如何用PHP把RDF内容插入Web站点之中(2)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />  <lirdf:resource="http://www.melonfire.com/community/columns/trog/article.php?id=71" /><lirdf:resource="http://www.melonfire.com/community

如何用PHP把RDF内容插入Web站点之中(三)

web|插入|站点 筑巢时间(Nesting Time) 前面的例子只是用来说明问题的.如果你真想把RDF内容插入到Web站点当中,就需要把事情做的更好一些.所以把前面的脚本的作了改进,新增了一些东西,从而简化格式化RDF数据的任务. <html><head><basefont face="Verdana"></head><body> <table border="0" cellspacing=&qu

如何用PHP把RDF内容插入Web站点之中(3)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />  }} // destroy parserxml_parser_free($xp), // opening tag handlerfunction elementBegin($parser, $name, $attributes){global $currentTag, $flag,// export the name o

如何用PHP把RDF内容插入Web站点之中(五)

web|插入|站点 免费午餐(A Free Lunch) 上面我所写的那个类也是很基本的,是拿来说明问题的,或许也可以用于低访问量的站点.如果你想寻找一些更专业的东西,去网上吧,那里有许多的开放源码的RDF分析器,他们带有各种附加的功能(包括缓存). 那么就让我们看一些如何运用这些分析器的例子吧. 第一个要讲的是由Stefan Saasen 为fase4网站开发的RDF分析器类,可以从http://www.fase4.com/rdf/上免费下载.这是一个功能非常齐全的RDF分析器,支持缓存和通过

如何用PHP把RDF内容插入Web站点之中(四)

web|插入|站点 返回到类(Back To Class) 既然你有这么大的权力,那么究竟为什么要把自己限制在仅仅是单个的RDF来源呢?就象我早先说过的一样,大多数主要的站点都经常为他们所提供的内容做快照.其实将所有这些不同的来源插入到你的站点当中是相当简单的.让我们看看是如何做的. 首先,我们把前面例子中的代码模块化.这样一来,你就无须为每一个单个的来源都一遍又一遍的重写相同的代码了.简化的方法就是将之打包成类,再把这个类包含到我的PHP脚本当中. 类代码如下: <?class RDFPars

如何用PHP把RDF内容插入Web站点之中(二)

web|插入|站点 既然从技术上讲,RSS是结构良好的XML文档,所以可以用标准的XML编程技术来处理它.主要有两种技术:SAX(the Simple API for XML)和DOM(the Document Object Model). SAX分析器工作时遍历整个XML文档,在遇到不用类型的标记时调用特定的函数.比如,调用特定函数处理一个开始标记,调用另一个函数处理一个结束标记,再调用一个函数处理两者之间的数据.分析器的职责仅仅是顺序遍历这个文档.而它所调用的函数负责处理发现的标记.一旦一个

如何用PHP把RDF内容插入Web站点之中(5)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />  if (!($fp = fopen($this->file, "r"))) {die("Could not read $this->file"),} // parse datawhile ($xml = fread($fp, 4096)) {if (!xml_parse

如何用PHP把RDF内容插入Web站点之中(4)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />  // this is an array of arrays, with each array element representing an<item> // each outer array element is itself an associative array // with keys ("