这个问题有两个部分。
第 1 部分。昨天我有一些代码可以回显来自 RSS 提要的 XML 的全部内容。然后我从我的 php 文档中删除它,保存它,我完全在踢自己。
我相信语法是这样的:
$xml = simplexml_load_file($url);
echo $xml;
我又试了一次,但它不起作用,所以显然我忘记了正确的语法,可以使用你的帮助,亲爱的 stackoverflow 问答者。
我一直试图弄清楚我在做什么,但我无法在 Google 或 PHP 网站上找到示例。我试过 print_r($url); 命令,它给了我似乎是一个原子化版本的提要。我想要整个字符串,疣和所有。我意识到我可以在窗口中键入 RSS 链接并查看它,但是在我编码和点头时将它放在我的 PHP 页面上很有帮助。
第 2 部分我想重建它的主要原因是因为我试图从博客 RSS 中解析节点,以便将其显示在托管在私有域上的网页上。我发布了一个虚拟博客,当我未能为其中一个虚拟帖子添加标题时,发现了一个尴尬的格式错误。
那么在这种情况下该怎么办呢?我试了一下:
if(entry->title == "")
{$entryTitle = "untitled";}
那根本行不通。
这是我处理博客的整个 php 脚本:
<?php
/*create variables*/
$subtitle ="";
$entryTitle="";
$html = "";
$pubDate ="";
/*Store RSS feed address in new variable*/
$url = "http://www.blogger.com/feeds/6552111825067891333/posts/default";
/*Retrieve BLOG XML and store it in PHP object*/
$xml = simplexml_load_file($url);
print_r($xml);
/*Parse blog subtitle into HTML and echo it on the page*/
$subtitle .= "<h2 class='blog'>" . $xml->subtitle . "</h2><br />";
echo $subtitle;
/*Go through all the entries and parse them into HTML*/
foreach($xml->entry as $entry){
/*retrieve publication date*/
$xmlDate = $entry->published;
/*Convert XML timestamp into PHP timestamp*/
$phpDate = new DateTime(substr($xmlDate,0,19));
/*Format PHP timestamp to something humans understand*/
$pubDate .= $phpDate->format('l\, F j\, Y h:i A');
if ($entry->title == "")
{
$entryTitle .= "Untitled";
}
echo $entry->title;
/*Pick through each entry and parse each XML tree node into an HTML ready blog post*/
$html .= "<h3 class='blog'>".$entry->title . "<span class='pubDate'> | " .$pubDate . "</span></h3><p class='blog'>" . $entry->content . "</p>";
/*Print the HTML to the web page*/
echo $html;
/*Set the variables back to empty strings so they do not repeat data upon reiteration*/
$html = "";
$pubDate = "";
}
?>