Ошибка синтаксического анализа XML: нежелательная после элемента документа при создании RSS-канала - PullRequest
0 голосов
/ 22 апреля 2010

Я использую следующий скрипт для создания RSS-канала для моего сайта:

<?php

class RSS
{
    public function RSS()
    {
            $root = $_SERVER['DOCUMENT_ROOT'];
        require_once ("../connect.php");
    }

    public function GetFeed()
    {
        return $this->getDetails() . $this->getItems();
    }

    private function dbConnect()
    {
        DEFINE ('LINK', mysql_connect (DB_HOST, DB_USER, DB_PASSWORD));
    }

    private function getDetails()
    {
        $detailsTable = "rss_feed_details";
        $this->dbConnect($detailsTable);
        $query = "SELECT * FROM ". $detailsTable ." WHERE feed_category = ''";
        $result = mysql_db_query (DB_NAME, $query, LINK);

        while($row = mysql_fetch_array($result))
        {
            $details = '<?xml version="1.0" encoding="ISO-8859-1" ?>
                    <rss version="2.0">
                        <channel>
                            <title>'. $row['title'] .'</title>
                            <link>'. $row['link'] .'</link>
                            <description>'. $row['description'] .'</description>
                            <language>'. $row['language'] .'</language>
                            <image>
                                <title>'. $row['image_title'] .'</title>
                                <url>'. $row['image_url'] .'</url>
                                <link>'. $row['image_link'] .'</link>
                                <width>'. $row['image_width'] .'</width>
                                <height>'. $row['image_height'] .'</height>
                            </image>';
        }
        return $details;
    }

    private function getItems()
    {
        $itemsTable = "rss_posts";
        $this->dbConnect($itemsTable);
        $query = "SELECT * FROM ". $itemsTable ." ORDER BY id DESC";
        $result = mysql_db_query (DB_NAME, $query, LINK);
        $items = '';
        while($row = mysql_fetch_array($result))
        {
            $items .= '<item>
                         <title>'. $row["title"] .'</title>
                         <link>'. $row["link"] .'</link>
                         <description><![CDATA['.$row["readable_date"]."<br /><br />".$row["description"]."<br /><br />".']]></description>
                     </item>';
        }
        $items .= '</channel>
                 </rss>';
        return $items;
    }

}

?>

Удивительно, что скрипт отлично работает на моем локальном хосте, но выдает следующую ошибку на моем удаленном сервере:

XML Parsing Error: junk after document element
Location: http://mysite.com/rss/main/
Line Number 2, Column 1:<b>Parse error</b>:  syntax error, unexpected T_STRING in <b>/home/studentw/public_html/rss/global-reach/rssClass.php</b> on line <b>1</b><br />
^

Ответы [ 2 ]

0 голосов
/ 22 апреля 2010

Попробуйте отправить правильный тип содержимого для ответа:

Вы можете попробовать следующее:

header("Content-Type:TYPE");

Где TYPE - одно из следующего:

text/xml
application/rss+xml
application/rdf+xml
application/atom+xml
0 голосов
/ 22 апреля 2010

Возможно, у вас есть какой-то посторонний символ, такой как табуляция или пробел, который отражается в файле XML на вашем удаленном сервере. Я бы использовал буферизацию вывода, чтобы очистить его перед печатью xml.

Обновление 1

Это с сайта PHP о буферизации вывода :

<?php

function callback($buffer)
{
  // replace all the apples with oranges
  return (str_replace("apples", "oranges", $buffer));
}

ob_start("callback");

?>
<html>
<body>
<p>It's like comparing apples to oranges.</p>
</body>
</html>
<?php

ob_end_flush();

?> 

Вместо того, чтобы заменять яблоки и апельсины, вы можете искать пробелы и табуляции.

...