我正在使用我的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输出?
答案 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实体,从而导致它们显示在浏览器中。)