php - 在 php 中放置 session 检查后无法显示表格

标签 php html mysql forms html-table

我添加了一些 if 条件和 php session 。现在它无法显示我的程序表。我得到一个错误:Undefined variable $result on line 79。在其他操作文件中,表格工作正常,它们会显示出来。

ac_directorProgramsYearsForm.php

<html>
<head>
 <link rel="stylesheet" type="text/css" href="../../statistics/style.css">
</head>
<body>

<div id="form">
<form name="myform" action="ac_directorProgramsYears.php" method="POST">

<b>Programs:<b/>
<select name="program"> 
<option value="Choose">Please select..</option>
    <?php
    $sql = mysql_query("SELECT prog_name FROM program");
    while ($row = mysql_fetch_array($sql)) {
        echo "<option value='".$row['prog_name']."'>".$row['prog_name'] ."</option>";
    }
    ?>  
</select><br/><br/>


<br/>
<input type="submit" value="submit" name="Submit">
<input type="reset" name="reset" value="Clear">

</form>
</div>
</body>
</html>

ac_directorProgramsYears.php

   <?php 

      include 'connect.php';


      $programs = array(
       'bsc_computer_science',
       'bsc_psychology',
       'ba_finance',
       'ba_marketing',
       'ba_management'
      );

if(isset($_POST['submit'])){

  $program = mysql_real_escape_string($_POST['program']); 

  session_start();

   if(!isset($_SESSION['username'])){

        header("location:../../statistics/main.htm");
   }
   $username=$_SESSION['username'];

   if(isset($_POST['program'])){


        $_SESSION['program'] = $_POST['program'];


        if (in_array($program, $programs)){

             $sql = "SELECT year,a1,a2,a3,l1,l2,l3,l4,l5,l6,l7,lavg,r1,r2,u1,u2,u3 FROM $program";

            $result = mysql_query($sql);
        }

        else {
             echo "No data found";
        }
     }
  }
?>
 <html>
 <head>
 <link rel="stylesheet" type="text/css" href="../../statistics/style.css">
 </head>
 <body>

 <div id="container">
   <table id="table" width="900" border="1" cellspacing="1">

   <tbody>
      <tr>
        <td>Year</td>
        <td>A1 </td>
        <td>A2 </td>
        <td>A3 </td>
        <td>L1 </td>
        <td>L2 </td>
        <td>L3 </td>
        <td>L4 </td>
        <td>L5 </td>
        <td>L6 </td>
        <td>L7 </td>
        <td>LAVG </td>
        <td>R1 </td>
        <td>R2 </td>
        <td>U1 </td>
        <td>U2 </td>
        <td>U3 </td>
       </tr>
  </tbody>
<?php
    while($director=mysql_fetch_assoc($result)){
        echo "<tr>";
        echo "<td>".$director['year']."</td>";
        echo "<td>".$director['a1']."</td>";
        echo "<td>".$director['a2']."</td>";
        echo "<td>".$director['a3']."</td>";
        echo "<td>".$director['l1']."</td>";
        echo "<td>".$director['l2']."</td>";
        echo "<td>".$director['l3']."</td>";
        echo "<td>".$director['l4']."</td>";
        echo "<td>".$director['l5']."</td>";
        echo "<td>".$director['l6']."</td>";
        echo "<td>".$director['l7']."</td>";
        echo "<td>".$director['lavg']."</td>";
        echo "<td>".$director['r1']."</td>";
        echo "<td>".$director['r2']."</td>";
        echo "<td>".$director['u1']."</td>";
        echo "<td>".$director['u2']."</td>";
        echo "<td>".$director['u3']."</td>";
        echo "</tr>";    
    }
?>
</table>
</div>
</body>
</html>

最佳答案

您的表格的显示取决于以下while 条件:

while($director=mysql_fetch_assoc($result)){

(我也相信这是您的错误的第 79 行)

错误意味着您没有设置变量 $result。由于它未定义,因此它也没有任何值(value) - 所以基本上您是在使用 undefined variable 而不是查询运行 mysql_fetch_assoc 函数。

现在,我注意到您在代码的顶部定义了一个名为 $result 的变量 但是,如果您仔细观察 - 您可以定义它if 条件else 选项中的变量 - 你不需要。

结论 - 您的脚本进入了 else block ,因此 $results 未定义。考虑调试您的代码以了解为什么 if 条件 返回 false 并转到 else block 。

    if (in_array($program, $programs)){//This condition return false so...
         $sql = "...."
        $result = mysql_query($sql);
    } else { //Your script runs this part of code
         echo "No data found";
        //$result is undefined in this case.
    }

请注意 您正在使用已弃用的 mysql_。考虑使用 PDOmysqli_

关于php - 在 php 中放置 session 检查后无法显示表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29962094/

相关文章:

javascript - 使用 jquery 在 php 中回显警报

javascript - 打开电子邮件客户端并使用 PHP/JavaScript 提交表单

javascript - 这段代码容易受到 XSS 攻击吗?

javascript - 按索引获取表行 ID

php - 使用 PDO Mysql 和 PHP 随机访问行集/结果集

php - ZF2 select 中的别名 - 带有计算字段

php - TYPO3 扩展中的动态数据库登录

php - 出现异常您的 FFProbe 版本太旧,不支持 `-help` 选项

javascript - 链接不适用于图像?

MySQL删除嵌套选择查询