我一直在努力解决这个问题,它一直困扰着我。代码是显示从下拉框中选择的一个表,它运行良好。。但当我把它和我的布局/模板放在一起时,它会抛出一个错误&我不知道为什么!
这是代码:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta name="keywords" content="" >
<meta name="description" content="" >
<meta http-equiv="content-type" content="text/html; charset=utf-8" >
<title>SNYSB Archive</title>
<link href="style.css" rel="stylesheet" type="text/css" media="screen" >
<!-- Location of javascript. -->
<script language="javascript" type="text/javascript" src="swfobject.js" ></script>
</head>
<div id="wrapper">
<div id="header">
<!-- KEEP THIS BIT [ITS FORMATTING] -->
</div>
<!-- end #header -->
<div id="menu">
<ul>
<li><a href="Hpage.php">Home</a></li>
<li><a href="Register.php">Register</a></li>
</ul>
</div>
<!-- end #menu -->
<div id="page">
<div id="page-bgtop">
<div id="page-bgbtm">
<div id="content">
<div class="post">
<div class="post-bgtop">
<div class="post-bgbtm">
<h1 class="title">PUT HEADING HERE!</h1>
<div class="entry">
<p class="Body">
<?php
$dbname = 'snysbarchive';
$conn= mysql_connect('localhost', 'root', 'usbw');
if (!$conn) {
echo 'Could not connect to mysql';
exit;
}
$sql = "SHOW TABLES FROM $dbname";
$result = mysql_query($sql);
if (!$result) {
echo "DB Error, could not list tables'n";
echo 'MySQL Error: ' . mysql_error();
exit;
}
if (mysql_select_db($dbname, $conn))
{
?>
<form method="post" action="new 2.php">
<select name="tables">
<?php
while ($row = mysql_fetch_row($result)) {
?>
<?php
echo '<option value="'.$row[0].'">'.$row[0].'</option>';
}
?>
</select>
<input type="submit" value="Show">
</form>
<?php
//mysql_free_result($result);
if (isset($_POST) && isset($_POST['tables']))
{
$tbl=$_POST['tables'];
//echo $_POST['tables']."<br />";
$query="SELECT * from $tbl";
$res=mysql_query($query);
echo $query;
if ($res)
{
?>
<table border="1">
<?php
while ( $row = mysql_fetch_array($res))
{
echo "<tr>";
echo "<td>".$row[0]."</td>";
echo "<td>".$row[1]."</td>";
echo "<td>".$row[2]."</td>";
echo "<td>".$row[3]."</td>";
echo "</tr>";
} ?>
</table>
<?php
}
}
?>
</div>
</div>
</div>
</div>
<div style="clear: both;"> </div>
</div>
<!-- end #content -->
<div id="sidebar">
<ul>
<li>
<h2>Welcome!</h2>
<p>Welcome to SNYSBs archive!
</p>
</li>
<li>
<h2>SNYSB</h2>
<p>
<a href="Contact.php">Contact Us!</a>
</p>
</li>
</ul>
</div>
<!-- end #sidebar -->
<div style="clear: both;"> </div>
</div>
</div>
</div>
<!-- end #page -->
<div id="footer">
<p>Copyright (c) 2008 Sitename.com. All rights reserved. Design by <a href="http://www.freecsstemplates.org/">Free CSS Templates</a>.</p>
</div>
<!-- end #footer -->
</div>
</body>
</html>
(只是在开始和底部粘贴了我的模板的原始页面的整个代码)
这是它不喜欢的一行:
if (isset($_POST['tables']))
感谢
编辑:新错误消息:分析错误:语法错误,第128行的FILENAME中出现意外$end
您看到的错误可能是因为$_POST没有名为"tables"的键。
echo"<form method="post" action="show_tabs.php">";
echo"<select name="tables">";
当我运行它们时,两者都会产生错误。请注意SO上高亮显示颜色变化的语法,这表明并非所有内容都被解释为字符串文字。您需要转义内部引号或将外部引号切换为单引号:
echo '<form method="post" action="show_tabs.php">';
echo '<select name="tables">';
或
echo "<form method='"post'" action='"show_tabs.php'">";
echo "<select name='"tables'">";
也是如此
echo"<input type="submit" value="Show">";
...
echo"<table border="1">";
此外,
if ($res)
}
应读取
if ($res)
{
此外,您在使用mysql_*函数时出现了一个错误。我可以看到您只有在运行了查询之后才选择数据库,并且我没有看到对mysql_connect
的调用。顺序为connect、select_db、query、fetch、free、close,如中所示http://www.php.net/manual/en/mysql.examples-basic.php
(以上代码更新后)将整件事包装在一个heredoc中显然是原因,而且是非常没有必要的。只需使用php打开和关闭标记即可在文本和代码之间切换。例如,代替
echo <<< TEMPLATE
<h1 class="title">PUT HEADING HERE!</h1>
<div class="entry">
<p class="Body">
使用
?>
<h1 class="title">PUT HEADING HERE!</h1>
<div class="entry">
<p class="Body">
<?php
heredoc内部的代码不会被执行(尽管变量被替换),所以从<<< TEMPLATE
到TEMPLATE;
的代码都没有运行。只有变量应该放在heredoc内部。
您的错误实际上早了3行;
echo"<input type="submit" value="Show">";
它可能应该使用单引号,以免与字符串中的双引号冲突;
echo '<input type="submit" value="Show">';
以及另外几行;
echo"<form method="post" action="show_tabs.php">";
...
echo"<table border="1">";
应该以同样的方式解决。
我认为你应该试试这个。。。
if (isset($_POST) && isset($_POST['tables']))