使用PHP生成XML文件

时间:2012-04-11 20:51:53

标签: php mysql xml

我目前有一个PHP脚本,在运行时会输出一个XML文件(但是作为feed.php而不是feed.xml)我被告知要将它添加到我的.htaccess中它应该修复它:

AddType application/x-httpd-php .xml

然而由于某些原因,这是行不通的。

我最喜欢的脚本是什么 - 当run是生成带有其内容输出的feed.xml文件时,而不是仅仅输出php页面上的内容。

这是我的代码:

<?PHP
 include("../config.php");
 #// Timetable Clearup Variabls
$yesterday = strtotime('yesterday');
$yesterdow = date('l',$yesterday);
$order = "SELECT * FROM timetable WHERE day = '$yesterdow' ORDER BY time";
$result = mysql_query($order);
$yesterdayd = date('F jS, Y', time()-86400);

    //SET XML HEADER
    header('Content-type: text/xml');

    //CONSTRUCT RSS FEED HEADERS
    $output = '<rss version="2.0">';
    $output .= '<channel>';
    $output .= "<title>Timetable - {$yesterdayd} </title>";
    $output .= '<description>Timetable.</description>';
    $output .= '<link>http://site.com/</link>';
 ###   $output .= '<copyright>Your copyright details</copyright>';
 while ($row = mysql_fetch_array($result)) {
    //BODY OF RSS FEED
   $output .= '<item>';
     $output .= "<description><td>" . htmlspecialchars($row['username']) . "</td><td>" . htmlspecialchars($row['time']) . "</td></description>";
   $output .= '</item> ';
 }
    //CLOSE RSS FEED
   $output .= '</channel>';
   $output .= '</rss>';

    //SEND COMPLETE RSS FEED TO BROWSER
    echo($output);

?>

1 个答案:

答案 0 :(得分:3)

我建议不要在.htaccess中添加.xml来使用PHP编译器进行处理。 而是使用 mod_rewrite 将.xml文件的请求重定向到php脚本。

例如:

RewriteEngine On
RewriteRule ^(.*)\.xml$ /rss_feed.php [L,QSA]