使用PHP将MySQL行转换为XML

时间:2014-03-10 21:18:31

标签: php mysql xml

我正在使用我的php脚本从mysql数据库输出信息。我想在我的php页面中输出这些echo结果作为xml文件,因为我想让它看起来像这样:

<?xml version="1.0" encoding="UTF-8" ?>
<tv generator-info-name="www.mysite.com/xmltv">
<channel id="">
   <display-name></display-name>
   <programme channel="" start="" stop="">
      <title lang="en"></title>
      <sub-title lang="en"></sub-title>
      <desc lang="en"></desc>
      <category lang="en"></category>
   </programme>
</channel>

这是我的PHP:

<?php

function db_connect()
{
  define('DB_HOST', 'localhost');
  define('DB_USER', 'myusername');
  define('DB_PASSWORD', 'mypasword');
  define('DB_DATABASE', 'mydbname');

  $errmsg_arr = array();
  $errflag = false;
  $link = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD);

  if(!$link) 
  {
    die('Failed to connect to server: ' . mysql_error());
  }

  $db = mysql_select_db(DB_DATABASE);
  if(!$db) 
  {
    die("Unable to select database");
  }
}
db_connect();


function clean($var)
  {
    return mysql_real_escape_string(strip_tags($var));
  } 
  $channels = clean($_GET['channels']);
  $id = clean($_GET['id']);

  if($errflag) 
  {
    $_SESSION['ERRMSG_ARR'] = $errmsg_arr;
    echo implode('<br />',$errmsg_arr);
  }
  else 
  {
    $insert = array();

    if(isset($_GET['channels'])) 
    {
      $insert[] = 'channels = \'' . clean($_GET['channels']) .'\'';
    }
    if(isset($_GET['id'])) 
    {
      $insert[] = 'id = \'' . clean($_GET['id']) . '\'';
    }


    if($channels && $id) 
    {
      $qrytable1="SELECT id, channels, links FROM tvguide WHERE channels='$channels' && id='$id'";
      $result1=mysql_query($qrytable1) or die('Error:<br />' . $qry . '<br />' . mysql_error());

      while ($row = mysql_fetch_array($result1))
      {
        zap2it($row);
      }
      mysql_close();
    }
    else if(!$channels && ! $id)
    {
      $qrytable1="SELECT id, channels, links, streams FROM tvguide";
      $result1=mysql_query($qrytable1) or die('Error:<br />' . $qry . '<br />' . mysql_error());
      echo '<?xml version=""1.0"" encoding="UTF-8" ?>';
      echo '<tv generator-info-name="www.mysite.com/xmltv">';
      echo '<channel id="">';
      echo '<display-name></display-name>';
      echo '<programme channel="" start="" stop="">';
      echo '<title lang="en"></title>';
      echo '<sub-title lang="en"></sub-title>';
      echo '<desc lang="en"></desc>';
      echo '<category lang="en"></category>';
      echo '</programme>';
      echo '</channel>';


      while ($row = mysql_fetch_array($result1)) 
      {
        echo "<p id='channels'>".$row["id"]. " " . $row["channels"]. "</p>";

        echo "<p id='links'>";
        echo "http://www.mysite.com/get-listing.php?channels=" . $row["channels"] . "&id=" . $row["id"] .'</p>';
      }
    }
  }
?>

这是我的php输出的样子:

<?xml version="1.0" encoding="UTF-8" ?><tv generator-info-name="www.mysite.com/xmltv"><channel id=""><display-name></display-name><programme channel="" start="" stop=""><title lang="en"></title><sub-title lang="en"></sub-title><desc lang="en"></desc><category lang="en"></category></programme></channel>

编辑:我有回音问题。我无法回显数据库中的频道。

if(!$channels && ! $id) 
    {
      $qrytable1="SELECT id, channels, links, streams FROM tvguide";
      $result1=mysql_query($qrytable1) or die('Error:<br />' . $qry . '<br />' . mysql_error());




  while ($row = mysql_fetch_array($result1)) 
  {

  }
  mysql_close();
}

以下是我遇到的错误:第11行第12行的错误:仅在文档开头允许XML声明

当我在while语句中使用它时,我会收到错误:

while ($row = mysql_fetch_array($result1)) 
      {
        echo '<?xml version="1.0" encoding="UTF-8" ?>
<tv generator-info-name="www.mysite.com/xmltv">
<channel id="">
   <display-name></display-name>
   <programme channel="" start="" stop="">
      <title lang="en"></title>
      <sub-title lang="en"></sub-title>
      <desc lang="en"></desc>
      <category lang="en"></category>
   </programme>
</channel>
</tv>';
      }

我的php输出显示为空白页面。你如何使用代码允许我在我的php中打印这些xml输出?

2 个答案:

答案 0 :(得分:0)

如果channel = 0且id = 0,则输出正确。它可能没有标签,但它对你的逻辑是正确的。

根据浏览器的不同,XML可能会显示空白页...请确保您查看代码!

你需要通过$ channel&amp;&amp ;;重新考虑你的逻辑。 $ id然后再做!$ channel&amp;&amp; !id很奇怪。

答案 1 :(得分:0)

看起来您已经成功生成了XML。您的问题是它显示为空白页面。这是预料之中的,因为您的Web浏览器会将XML解释为一堆HTML标记,并且标记不会显示。

您可能要做的是将内容类型设置为XML,以便Web浏览器知道它的XML而不是HTML。您可以通过在发送任何其他输出之前添加标头(即在任何echo语句之前)来执行此操作:

header('Content-type: application/xml');

这是必要的,因为如果您没有明确指定内容类型,服务器将自动发送一个内容类型标题,告诉浏览器该内容是HTML。

您可以使用浏览器的调试控制台(按F12在大多数现代浏览器中打开它)来检查脚本发送的HTTP标头,并验证它是否声明了正确的内容类型。


另一种方法是将XML格式化为HTML。这可能不是很理想,因为XML的目的是由其他客户端处理并将其转换为HTML使其无用。但是,如果您真的想要,可以通过将所有XML放在一个字符串中然后调用htmlspecialchars函数将其格式化为HTML来完成。 (这会将<>转换为HTML实体,从而导致它们显示在浏览器中。)