麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > PHP > 正文

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

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

筑巢時間(Nesting Time)

前面的例子只是用來說明問題的。如果你真想把RDF內容插入到Web站點當中,就需要把事情做的更好一些。所以把前面的腳本的作了改進,新增了一些東西,從而簡化格式化RDF數據的任務。

<html>
<head>
<basefont face="Verdana">
</head>
<body>

<table border="0" cellspacing="5" cellpadding="5">
<tr>
<td><b>New releases on freshmeat.net today:</b></td>
</tr>

<?php
// XML file
$file = "http://www.freshmeat.net/backend/fm-releases.rdf";

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

// this is an associative array of channel data with keys ("title",
"link",
"description")
$channel = array();

// this is an array of arrays, with each array element representing an
<item> // each outer array element is itself an associative array
// with keys ("title", "link", "description")
$items = array();

// opening tag handler
function elementBegin($parser, $name, $attributes)
{
 global $currentTag, $flag;
 $currentTag = $name;
 // set flag if entering <channel> or <item> block
 if ($name == "ITEM")
 {
/t   $flag = 1;
 }
 else if ($name == "CHANNEL")
 {
/t   $flag = 2;
 }
}

// closing tag handler      
function elementEnd($parser, $name)
{
 global $currentTag, $flag, $count;
 $currentTag = "";

 // set flag if exiting <channel> or <item> block
 if ($name == "ITEM")
 {
/t   $count++;
/t   $flag = 0;
 }
 else if ($name == "CHANNEL")
 {
/t   $flag = 0;
 }
}

// character data handler
function characterData($parser, $data)
{
 global $currentTag, $flag, $items, $count, $channel;
 $data = trim(htmlspecialchars($data));
 if ($currentTag == "TITLE" || $currentTag == "LINK" ||
$currentTag ==
"DESCRIPTION")
 {
/t   // add data to $channels[] or $items[] array
/t   if ($flag == 1)
/t   {
/t/t   $items[$count][strtolower($currentTag)] .=
$data;
/t   }
/t   else if ($flag == 2)
/t   {
/t/t   $channel[strtolower($currentTag)] .= $data;
/t   }
 }

}

// 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);
xml_parser_set_option($xp, XML_OPTION_SKIP_WHITE, 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);

// now iterate through $items[] array
// and print each item as a table row
foreach ($items as $item)
{
 echo "<tr><td><a href=" . $item["link"] . ">" . $item["title"] .
"</a><br>" . $item["description"] .  "</td></tr>"; }

?>
</table>
</body>
</html>

與先前的那段的主要區別在于,這段腳本創建了兩個數組,用于保存分析過程中所提取的信息。其中,$channel是聯合性數組(associative array),存放被處理的頻道的基本描述信息,而$items是一個二維數組,包含關于單獨的頻道條目(channel intems)的信息。$items數組中的每一個元素本身又是一個聯合性數組,包含title,URL和description關鍵字。$items數組中元素總數與RDF文檔中的<item>區塊總數相同。

還需注意$flag變量的變化,根據被處理的是<channel></channel>區塊還是<item></item>區塊,它現在保存兩個值。這一點很有必要,因為只有這樣,分析器才能把信息放入正確的數組里面。

一旦文檔分析完畢,事情就簡單了――遍歷$items 數組,以表格形式打印其中的每一個條目(item)。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久久久久久久久亚洲精品 | 综合网日日天干夜夜久久 | 欧美一级黄色网 | gril hd| 精品国产91久久久久久久 | 国产九九九九 | v片在线看 | 欧美一区二区三区免费不卡 | 蜜桃视频最新网址 | 爽毛片| 在线播放av网址 | 99热1| 91看片在线观看视频 | 国产午夜三级一区二区三桃花影视 | 国产免费观看一区二区三区 | fc2国产成人免费视频 | 国产成人在线观看免费网站 | 欧美精品免费一区二区三区 | 免费啪啪| 久久久中文 | 久久久国产精品电影 | 亚洲综合网站 | 色污视频在线观看 | 精品一区二区三区电影 | 久久性生活免费视频 | 国产亚洲精品成人 | 成人一级免费视频 | 亚洲国产精品500在线观看 | 欧美 亚洲 视频 | 久久精品视频一区二区三区 | 亚洲最大中文字幕 | 国产亚洲精品久久久久久久久久 | 国产视频在线观看免费 | 成人做爽爽爽爽免费国产软件 | 国产精品一区在线观看 | 久久国产28 | 最近免费观看高清韩国日本大全 | www.91pron| 一边吃奶一边插下面 | 国产精品av久久久久久久久久 | a级黄色片视频 |