亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

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

2019-09-08 23:11:15
字體:
來源:轉載
供稿:網友

鮮肉

既然從技術上講,RSS是結構良好的XML文檔,所以可以用標準的XML編程技術來處理它。主要有兩種技術:SAX(the Simple API for XML)和DOM(the Document Object Model)。

SAX分析器工作時遍歷整個XML文檔,在遇到不用類型的標記時調用特定的函數。比如,調用特定函數處理一個開始標記,調用另一個函數處理一個結束標記,再調用一個函數處理兩者之間的數據。分析器的職責僅僅是順序遍歷這個文檔。而它所調用的函數負責處理發現的標記。一旦一個標記被處理完畢,分析器繼續分析文檔中的下一個元素,這一過程不斷重復。

另一方面,DOM分析器工作是把整個XML文檔讀進內存當中,并將之轉換成一種分層的樹型結構。而且為訪問不同的樹結點(以及結點所附的內容)提供了API。遞歸處理方式加上API函數使得開發者能夠區分不同類型的結點(元素,屬性,字符數據,注釋等),同時根據文檔樹的結點類型和結點深度,使得執行不同的動作成為可能。

SAX和DOM分析器幾乎支持每一種語言,包括你我的最愛――PHP。我將在這篇文章中利用PHP的SAX分析器處理RDF的例子。 當然,使用DOM分析器也同樣很容易。

讓我們看這個簡單的例子,把它記在腦海里。下面是一個我將要使用的RDF文件,這個文件直接選自http://www.freshmeat.net/ :

<?xml version="1.0" encoding="ISO-8859-1"?>
<rdf:RDF  xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns="http://purl.org/rss/1.0/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
>
 <channel rdf:about="http://freshmeat.net/">
   <title>freshmeat.net</title>
   <link>http://freshmeat.net/</link>
   <description>freshmeat.net maintains the Web's largest index of Unix
and cross-platform open source software. Thousands of applications are
meticulously cataloged in the freshmeat.net database, and links to new
code are added daily.</description>
   <dc:language>en-us</dc:language>
   <dc:subject>Technology</dc:subject>
   <dc:publisher>freshmeat.net</dc:publisher>
   <dc:creator>freshmeat.net contributors</dc:creator>
   <dc:rights>Copyright (c) 1997-2002 OSDN</dc:rights>
   <dc:date>2002-02-11T10:20+00:00</dc:date>
   <items>
     <rdf:Seq>
       <rdf:li rdf:resource="http://freshmeat.net/releases/69583/" />
       <rdf:li rdf:resource="http://freshmeat.net/releases/69581/" />
       
     <!-- and so on -->

     </rdf:Seq>
   </items>
   <image rdf:resource="http://freshmeat.net/img/fmII-button.gif" />
   <textinput rdf:resource="http://freshmeat.net/search/" />
 </channel>

 <image rdf:about="http://freshmeat.net/img/fmII-button.gif">
   <title>freshmeat.net</title>
   <url>http://freshmeat.net/img/fmII-button.gif</url>
   <link>http://freshmeat.net/</link>
 </image>

 <item rdf:about="http://freshmeat.net/releases/69583/">
   <title>sloop.splitter 0.2.1</title>
   <link>http://freshmeat.net/releases/69583/</link>
   <description>A real time sound effects program.</description>
   <dc:date>2002-02-11T04:52-06:00</dc:date>
 </item>

 <item rdf:about="http://freshmeat.net/releases/69581/">
   <title>apacompile 1.9.9</title>
   <link>http://freshmeat.net/releases/69581/</link>
   <description>A full-featured Apache compilation HOWTO.</description>
   <dc:date>2002-02-11T04:52-06:00</dc:date>
 </item>

<!-- and so on -->

</rdf:RDF>

下面是分析這一文檔并顯示其中數據的PHP腳本:

 <?php
// XML file
$file = "fm-releases.rdf";

// set up some variables for use by the parser
$currentTag = "";
$flag = "";

// create parser
$xp = xml_parser_create();

// set element handler
xml_set_element_handler($xp, "elementBegin", "elementEnd");
xml_set_character_data_handler($xp, "characterData");
xml_parser_set_option($xp, XML_OPTION_CASE_FOLDING, TRUE);

// read XML file
if (!($fp = fopen($file, "r")))
{
     die("Could not read $file");
}

// parse data
while ($xml = fread($fp, 4096))
{
   if (!xml_parse($xp, $xml, feof($fp)))
   {
/t   die("XML parser error: " .
xml_error_string(xml_get_error_code($xp)));
   }
}

// destroy parser
xml_parser_free($xp);

// opening tag handler
function elementBegin($parser, $name, $attributes)
{
 global $currentTag, $flag;
 // export the name of the current tag to the global scope
 $currentTag = $name;
 // if within an item block, set a flag
 if ($name == "ITEM")
 {
/t   $flag = 1;
 }
}

// closing tag handler      
function elementEnd($parser, $name)
{
 global $currentTag, $flag;
 $currentTag = "";
 // if exiting an item block, print a line and reset the flag
 if ($name == "ITEM")
 {
/t   echo "<hr>";
/t   $flag = 0;
 }
}

// character data handler
function characterData($parser, $data)
{
 global $currentTag, $flag;
 // if within an item block, print item data
 if (($currentTag == "TITLE" || $currentTag == "LINK" ||
$currentTag ==
"DESCRIPTION") && $flag == 1)
 {
/t   echo "$currentTag: $data <br>";
 }
}

?>

看不明白? 別著急,后面將會作出解釋。

捕獲旗標

這段腳本首先要做的是設定一些全局變量:

// XML file
$file = "fm-releases.rdf";

// set up some variables for use by the parser
$currentTag = "";
$flag = "";

$currentTag變量保存是分析器當前處理的元素的名稱――你很快就會看到為什么需要它。

因為我的最終目的是顯示頻道中的每一個單獨的條目(item),并且帶有鏈結。另外還要知道分析器什么時候退出了<channel></channel>區塊,什么時候又進入了文檔的 <item></item>部分。再說我用的是SAX分析器,它按順序方式工作,沒有任何分析器API可供使用,無法知道文檔樹中的深度和位置。所以,我不得不自己發明一個機制來做這件事――這就是引入$flag變量的原因。

$flag變量將用于判斷分析器是在<channel>區塊還是在<item>區塊里面。

下一步要做的是初始化SAX分析器,并開始分析RSS文檔。

// create parser
$xp = xml_parser_create();

// set element handler
xml_set_element_handler($xp, "elementBegin", "elementEnd");
xml_set_character_data_handler($xp, "characterData");
xml_parser_set_option($xp, XML_OPTION_CASE_FOLDING, TRUE);

// read XML file
if (!($fp = fopen($file, "r")))
{
     die("Could not read $file");
}

// parse data
while ($xml = fread($fp, 4096))
{
   if (!xml_parse($xp, $xml, feof($fp)))
   {
/t   die("XML parser error: " .
xml_error_string(xml_get_error_code($xp)));
   }
}

// destroy parser
xml_parser_free($xp);

這段代碼簡單明了,其中的注釋已經解釋的足夠清楚了。xml_parser_create()函數建立一個分析器實例,并將之賦給句柄$xp。接著再創建回調函數處理開標記和閉標記,以及二者之間的字符數據。最后,xml_parse()函數聯合多次fread()調用,讀取RDF文件并分析它。

在文檔中,每次遇到開標記,開標記處理器elementBegin()就會被調用。

// opening tag handler
function elementBegin($parser, $name, $attributes)
{
 global $currentTag, $flag;
 // export the name of the current tag to the global scope
 $currentTag = $name;
 // if within an item block, set a flag
 if ($name == "ITEM")
 {
/t   $flag = 1;
 }
}

這個函數以當前標記的名稱和屬性作為起參數。標記名稱被賦值給全局變量$currentTag。如果,這個開標記是<item>,那么把$flag變量置1。

同樣,如果遇到閉標記,那么閉標記處理器elementEnd()將被調用。

// closing tag handler      
function elementEnd($parser, $name)
{
 global $currentTag, $flag;
 $currentTag = "";
 // if exiting an item block, print a line and reset the flag
 if ($name == "ITEM")
 {
/t   echo "<hr>";
/t   $flag = 0;
 }
}

閉標記處理函數也是以標記名稱作為其參數。如果是遇到的是一個為</item>的閉標記,變量$flag的值重置為0,并把變量$currentTag的值清空。

那么,如何處理標記之間的字符數據呢? 這才是我們的興趣所在。先向字符數據處理器characterData()打個招呼吧。

// character data handler
function characterData($parser, $data)
{
 global $currentTag, $flag;
 // if within an item block, print item data
 if (($currentTag == "TITLE" || $currentTag == "LINK" ||
$currentTag ==
"DESCRIPTION") && $flag == 1)
 {
/t   echo "$currentTag: $data <br>";
 }
}

現在你可以看一下傳給這個函數的參數,你會發現它只接收了開標記和閉標記之間的數據,而根本不知道分析器當前正在處理哪個標記。而這正事我們一開始就引入全局變量$currentTag的原因。

如果$flag變量的值為1,也就是說如果分析器當前處于<item></itme>區塊之間,那么當前被處理的元素,不管是<title>,<link>還是<description>,數據都被打印到輸出設備上(在這里,輸出設備是Web瀏覽器),并在每個元素的輸出后面加上換行符<br>。

整個RDF文檔就是以這種順序方式處理,每發現一個<item>標記就顯示一定的輸出。你可以看一下下面的運行結果:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美极品第一页| 国产欧美一区二区三区四区| 最近更新的2019中文字幕| 97av在线影院| 美女福利精品视频| 国产精品久久久久久久久久三级| 欧美日韩在线视频首页| 国产成人在线播放| 日韩中文在线中文网在线观看| 久久av中文字幕| 国模精品视频一区二区三区| 26uuu亚洲国产精品| 亚洲一区二区三区在线免费观看| 亚洲一级免费视频| 亚洲第一福利网站| 欧美大片大片在线播放| 国产精品久久久久久久久免费| 2020欧美日韩在线视频| 国自产精品手机在线观看视频| 欧美一级成年大片在线观看| 中文字幕精品www乱入免费视频| zzijzzij亚洲日本成熟少妇| 久久夜色精品国产欧美乱| 日韩免费电影在线观看| 久久99精品国产99久久6尤物| 久久精品国产久精国产思思| 日韩精品中文字幕在线播放| 亚洲欧美变态国产另类| 欧美激情女人20p| 97精品伊人久久久大香线蕉| 尤物九九久久国产精品的特点| 狠狠操狠狠色综合网| 久热精品视频在线观看一区| 2018中文字幕一区二区三区| 国产精品极品美女在线观看免费| 国产精品27p| 日韩免费在线看| 一色桃子一区二区| 国产综合久久久久| 久久人人爽人人爽人人片av高清| 色与欲影视天天看综合网| 亚洲免费视频在线观看| 日韩av免费看| 精品视频在线观看日韩| 欧美日韩高清在线观看| 日本a级片电影一区二区| 国产精品第一视频| 黄色一区二区在线| 91亚洲精品久久久| 国产精品91久久| 欧美猛男性生活免费| 26uuu亚洲国产精品| 亚洲免费视频一区二区| 久久精品国产99国产精品澳门| 国产精品女人久久久久久| 久久精品国产69国产精品亚洲| 欧美性猛xxx| 69精品小视频| 成人黄色片在线| 欧美性高跟鞋xxxxhd| 久久久久久久影视| 欧美性少妇18aaaa视频| 亚洲一区中文字幕在线观看| 亚洲国产成人精品久久久国产成人一区| 国产99在线|中文| 亚洲精品国产品国语在线| 欧美另类69精品久久久久9999| 日韩av在线影院| 日本免费久久高清视频| 欧美性极品xxxx做受| 久久久久久久久91| 亚洲加勒比久久88色综合| 日韩**中文字幕毛片| 日韩亚洲欧美成人| 久久免费视频在线| 国产91精品网站| 成人精品在线观看| 亚洲精品电影在线| 欧美激情视频播放| 日韩网站在线观看| 久久久午夜视频| 日本在线观看天堂男亚洲| 欧美亚洲第一页| 欧美做受高潮电影o| 欧美最猛性xxxxx亚洲精品| 一本大道香蕉久在线播放29| 91免费版网站入口| 亚洲天堂日韩电影| 18久久久久久| 亚洲性夜色噜噜噜7777| 中文日韩电影网站| 国产精品电影网站| 欧美午夜精品久久久久久人妖| 国产精品白嫩美女在线观看| 久久久久999| 91久久国产婷婷一区二区| 日韩高清电影好看的电视剧电影| 秋霞成人午夜鲁丝一区二区三区| 亚洲综合成人婷婷小说| 国产亚洲欧美日韩精品| www.欧美精品一二三区| 91精品国产精品| 亚洲国产精品va在线看黑人动漫| 97在线免费观看| 亚洲国产精品成人一区二区| 欧美大奶子在线| 亚洲免费av电影| 亚洲最大的av网站| 亚洲大胆人体av| 亚洲v日韩v综合v精品v| 国产精品久久久久秋霞鲁丝| 久久久精品视频成人| 久久精品中文字幕免费mv| 亚洲成人久久一区| 成人在线播放av| 亚洲护士老师的毛茸茸最新章节| 欧美韩国理论所午夜片917电影| 国产精品吴梦梦| 日韩中文视频免费在线观看| 亚洲一区久久久| 亚洲xxxx18| 亚洲国产成人精品电影| 欧美一级视频一区二区| 欧美激情在线视频二区| 国产精品久久久久久影视| 国产成人+综合亚洲+天堂| 日韩一区二区欧美| 精品国产老师黑色丝袜高跟鞋| 色久欧美在线视频观看| 国产精品白丝jk喷水视频一区| 国产精品久久久久久久久久ktv| 国产精品久久不能| 久久中文字幕在线| 97视频在线观看免费高清完整版在线观看| 欧美高清自拍一区| 亚洲天堂日韩电影| 亚洲自拍偷拍色片视频| 日韩精品在线第一页| 亚洲国产精彩中文乱码av在线播放| 色阁综合伊人av| 欧美一级大片在线免费观看| 亚洲成人av片| 精品国产福利在线| 91天堂在线观看| 欧美伦理91i| 日韩久久午夜影院| 亚洲另类欧美自拍| 性色av香蕉一区二区| 日韩精品在线免费| 一本色道久久88综合日韩精品| 欧美激情手机在线视频| 91精品国产一区| 亚洲欧美日韩天堂一区二区| 欧美国产日韩一区二区三区| 亚洲成av人乱码色午夜| 福利精品视频在线| 色综合视频网站| 久久久亚洲欧洲日产国码aⅴ| 久久久精品免费| 在线丨暗呦小u女国产精品| 中文字幕欧美日韩| 中文字幕成人精品久久不卡| 亚洲影院高清在线| 久久精品国产一区二区三区|