PHP Dropdown框没有填充

时间:2012-08-01 18:03:31

标签: php drop-down-menu

我正在尝试从数据库中的数据中填充一个下拉框,但它似乎不起作用。它传递了一个错误,说数据库中没有数据供它读取,但有。下面是我用来使其工作的脚本。

    <?php
@ini_set('display_errors', 'on');
 echo "<h1>Register</h1>";
if ($_SERVER['REQUEST_METHOD'] == 'POST'){

$errors = array();
if (empty($_POST['firstname'])){
$errors[] = 'Your forgot to enter your first name.';
}else{
  $firstname = trim($_POST['firstname']);
  }
if (empty($_POST['lastname'])){
$errors[] = 'Your forgot to enter your last name.';
}else{
  $lastname = trim($_POST['lastname']);
}
if (empty($_POST['username'])){
$errors[] = 'Your forgot to enter your  username.';
}else{
  $username = trim($_POST['username']);
}
if (!empty($_POST['password1'])) {
if ($_POST['password1'] != $_POST ['password2']) {
  $errors[] = 'Your password did not match the confirmed password!';
 }else{
   $password = trim($_POST['password1']);
  }
} else {
  $errors[] = 'You forgot to enter your password!';
}
if (empty($_POST['birthdate'])){
$errors[] = 'Your forgot to enter your  birthdate.';
}else{
  $birthdate = trim($_POST['birthdate']);
}
if (empty($_POST['gamespyid'])){
$errors[] = 'Your forgot to enter your  gamespy id.';
}else{
  $gamespyid = trim($_POST['gamespyid']);
}
  if (empty($errors)) {
     if (is_file('admin/mysqli_connect.php')) { echo '<p>The connection file is there.</p>';require('admin/mysqli_connect.php'); }

else {
  echo '<p>The connection file is not there</p>';
  }
     $q="INSERT INTO Users (firstname, lastname, username, password1, birthdate, gamespyid, base) VALUES ('$firstname', '$lastname', '$username', md5('$password1'), '$birthdate', '$gamespyid', '$base')";
$r = mysql_query($dbc, $q);
if ($r){
 echo'<p>You are now registered</p>';
}else{
  echo'<p>You have not been registered</p>';
                                            }
  } else {
    echo 'Error<br> <p>The following errors have occured:<br/>';
    foreach ($error as $msg) {
      echo " - $msg<br/>\n";
    }
    echo '</p><p>Please try again.</p><p><br/></p>';
  }   //if no errors

 }     //submit

?>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN">
<html>
<head>
  <title></title>
</head>

<body>
  <form action="http://www.virtual-aviation.org/gatewayaviation/index.php?p=register" method='POST'>
    <table summary="REgform">
      <tr>
        <td>First Name:</td>

        <td><input type='text' name='firstname' value='<?php echo $firstname; ?>'></td>
      </tr>

      <tr>
        <td>Last Name:</td>

        <td><input type='text' name='lastname'value='<?php echo $lastname; ?>'></td>
      </tr>

      <tr>
        <td>Username:</td>

        <td><input type='text' name='username'value='<?php echo $username; ?>'></td>
      </tr>

      <tr>
        <td>Password:</td>

        <td><input type='password' name='password1'></td>
      </tr>

      <tr>
        <td>Repeat Password:</td>

        <td><input type='password' name='password2'></td>
      </tr>

      <tr>
        <td>Birthdate:</td>

        <td><input type='text  ' name='birthdate'value='<?php echo $birthdate; ?>'></td>
      </tr>

      <tr>
        <td>Gamespy Id:</td>

        <td><input type='text' name='gamespyid'value='<?php echo $gamespyid; ?>'></td>
      </tr>
       <td>Base:</td>
      <tr>
       <td><select name="base" size="1">
          <option>
            Select One
          </option>
         <?php
         $qf = "SELECT  airport_id, CONCAT_WS(' ', airport_name, airport_code) FROM airports ORDER BY airport_code ASC";
         $rf = mysqli_query ($dbc, $qf);

         if (mysqli_num_rows($rf) > 0) {
         while ($row = mysql_fetch_array ($rf, MYSQLI_NUM)) {
         echo "<option value=\"$row[0]\"";
         if (isset($_POST['existing']) && ($_POST['existing'] == $row[0]) ) echo 'selected="selected"'; echo ">$row[1]</option>\n";
         }
   } else {
   echo '<option>Please a new airport first.</option>';
    }
    //mysqli_close($dbc);

         ?>
        </select></td>
      </tr>
    </table>
   <input type='submit' name='submit' value='Register'/>
  </form>
  <?php
  echo '<p>debugger<p>' . $rf ;
  ?>
</body>
</html>

以下是我查看源代码时遇到的一些错误;错误出现在选项框内容的位置。

警告:mysqli_query()要求参数1为mysqli,null为 /home5/virtua15/public_html/gatewayaviation/pages/register.inc.php 182

警告:mysqli_num_rows()要求参数1为mysqli_result,在 /home5/virtua15/public_html/gatewayaviation/pages/register.inc.php 行中给出null 184

Please a new airport first.

3 个答案:

答案 0 :(得分:2)

使用mysql_ *或mysqli_ *函数,但不能同时使用它们。我希望你选择后者并了解准备好的陈述:http://php.net/manual/en/mysqli.quickstart.prepared-statements.php

问题是你的$dbc变量很可能是mysql资源或null ,而不是mysqli资源,因此当你将它传递给mysqli_ *函数时它会失败。有多种方法可以检查并确保您拥有有效的资源:

$mysqli = new mysqli("example.com", "user", "password", "database");
if ($mysqli->connect_errno) {
    echo "Failed to connect to MySQL: (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
}

要解决您的问题,您需要重新构建代码以使用 mysqli,并确保$dbc是有效的mysqli资源。

答案 1 :(得分:0)

在您的示例的第123行,您有$rf = mysqli_query ($dbc, $qf);参数#1是$dbc,即MySQL连接对象。错误消息指出连接对象是null,这是真的 - 它没有在脚本中的任何位置声明。

答案 2 :(得分:0)

好吧,

警告:mysqli_query()要求参数1为mysqli,在第182行的/home5/virtua15/public_html/gatewayaviation/pages/register.inc.php中给出null

是因为你不能使用mysqli_query($ dbc,$ qf);当$ dbc不是从mysql_connect或mysql_init返回时,因为它期望链接作为第一个参数,并返回它所需的链接。

这也是您收到第二个错误的原因。 mysqli没有向$ rf返回任何内容。

我建议重构整个页面。首先给出变量有意义的名称,转义SQL字符串参数以帮助避免注入。

清除这些警告并再次拍摄。