通过POST方法提交HTML表单时未定义的索引

时间:2013-04-23 00:57:34

标签: php html forms indexing undefined

我一直在寻找为什么这段代码不起作用的日子。通过搜索具有相同问题的帖子多次调整代码。

问题:我的php文件似乎没有通过POST方法从简单的HTML表单(w。bootstrap)获取所需的值。我使用issit函数检查是否已单击提交按钮,然后我用来检查表单是否已完全填写。

请注意我对php比较新。我希望我确实错过了一些东西,这不仅仅是一个简单的拼写错误。

PHP代码(bootstrap / php / boeking.php)

<?php

//<!--debug-->

error_reporting(E_ALL);
ini_set('display_errors', '1');


//<!--connectie-->

mysql_connect("localhost","root","root") or die(mysql_error());
mysql_select_db("hota") or die(mysql_error());


//<!--boeking info verzenden-->

if(isset($_POST['send']))

{

if (isset($_POST['achternaam'])) 
{
   $anaam = $_POST['achternaam'];
   // do whatever here
}

if(isset($_POST['voornaam']))
{
$vnaam =  $_POST['voornaam'];

}

}



$anaam = mysql_real_escape_string($anaam);
$vnaam = mysql_real_escape_string($vnaam);


$boek = "INSERT INTO klant (achternaam , voornaam) VALUES ('{$anaam}', '{$vnaam}')";

mysql_query($boek);

?>

HTML code:

<form id="newbook" method="POST" action="bootstrap/php/boeking.php" class="form-horizontal">
  <legend>Nieuwe boeking</legend>
   <div class="control-group">
      <label class="control-label" for="voornaam">Voornaam</label>
      <div class="controls">
        <input type="text" name="voornaam" id="voornaam" placeholder="Voornaam">
      </div>
   </div>
   <div class="control-group">
      <label class="control-label" for="achternaam">Achternaam</label>
      <div class="controls">
        <input type="text" name="achternaam" id="achternaam" placeholder="Achternaam">
      </div>
    </div>
   <div class="control-group">
      <div class="controls">
        <button type="submit" name="send" class="btn">Sign in</button>
      </div>
   </div>
  </form>

提前致谢!

更新:

改变了我的php代码。

不再获取未定义的索引错误。
后续代码var_dump($ vnaam);和var_dump($ anaam);确实指出字符串被传递给php但是在那之后,当触发查询时,事情似乎没有被发送到数据库。

这可能是我查询中的问题吗?

(已经感谢提示了:给了按钮一个值并使用了var_dump)

这是我的新代码:

<?php

//<!--debug-->

error_reporting(E_ALL);
ini_set('display_errors', '1');


//<!--connectie-->

mysql_connect("localhost","root","root") or die(mysql_error());
mysql_select_db("hota") or die(mysql_error());


$anaam = '';
$vnaam = '';


if(!isset($_POST['send'])) { 

} 
 else
{

if (isset($_POST['achternaam'])) 
{
   $anaam = $_POST['achternaam'];
   // do whatever here

}

if(isset($_POST['voornaam']))
{
$vnaam =  $_POST['voornaam'];


}
var_dump($vnaam);
var_dump($anaam);


    $anaam = mysql_real_escape_string($anaam);
    $vnaam = mysql_real_escape_string($vnaam);

}

var_dump($vnaam);


$boek = "INSERT INTO klant (achternaam , voornaam) VALUES ('{$anaam}', '{$vnaam}')";

mysql_query($boek);

?>

5 个答案:

答案 0 :(得分:1)

编辑:

您需要为按钮指定,否则isset将返回false。


目前还不清楚你是否还有未定义的索引错误,但是如果你已经过了那个尝试在if语句之外声明你的变量。

$anaam = '';
$vnaam = '';

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

    if (isset($_POST['achternaam'])) 
    {
       $anaam = $_POST['achternaam'];
       // do whatever here
    }

    if(isset($_POST['voornaam']))
    {
        $vnaam =  $_POST['voornaam'];    
    }
}

答案 1 :(得分:1)

您可以通过输出带有var_dump()的$ _POST变量进行调试,看看是否有任何内容。

如果没有,您确定没有将浏览器重定向到您尝试查找值的页面吗?

如果设置了某些内容,那么isset($ _ POST [“send”])可能会返回false。

请使用PDO而不是那些即将被弃用和错误的mysql_函数。

答案 2 :(得分:1)

您可以尝试使用:

替换

<button type="submit" name="send" class="btn">Sign in</button>

<input type="submit" name="send" value="Sign in" />

   if(isset($_POST['send']))

    {

    if (isset($_POST['achternaam'])) 
    {
       $anaam = $_POST['achternaam'];
       // do whatever here
    }

    if(isset($_POST['voornaam']))
    {
    $vnaam =  $_POST['voornaam'];

    }

    }

    $anaam = mysql_real_escape_string($anaam);
    $vnaam = mysql_real_escape_string($vnaam);
    [...]

if(!isset($_POST['send'])) { 
    echo " No valid Post ";
} 
 else
{

if (isset($_POST['achternaam'])) 
{
   $anaam = $_POST['achternaam'];
   // do whatever here
}

if(isset($_POST['voornaam']))
{
$vnaam =  $_POST['voornaam'];

}

    $anaam = mysql_real_escape_string($anaam);
    $vnaam = mysql_real_escape_string($vnaam);
    [...]
}

可点击按钮

<button type="submit" name="send" class="btn">Sign in</button>

要指定单击按钮时应发生的情况,您可以使用例如side onclick事件处理程序。分配给事件处理程序属性的值,然后您可以编写JavaScript代码。

在其他方面,这些按钮用于传统的同类产品:没有JavaScript,它们完全无功能

答案 3 :(得分:1)

通过调整我在原始帖子中写的更新中看到的代码来解决未定义索引的问题。在该问题解决之后,由于PRIMARY KEY的DUPLICATE,查询拒绝触发并将数据放入数据库中。解决这个问题后,它就像一个魅力。这些信息是否足以帮助人们面对一些相同的问题或者我应该更彻底?

无论如何,非常感谢所有响应者!

答案 4 :(得分:0)

试试这个......

if($_SERVER['REQUEST_METHOD'] == 'POST'){

   $voornaam = $_POST['voornaam'];
   $achternaam = $_POST['achternaam'];

   // Validate post input here

   // Please use PDO or MySQLi at least. It's easier than it looks...
   try {
       $conn = new PDO("mysql:host=$db_host;dbname=$db_name", $db_user, $db_pass, array(PDO::ATTR_PERSISTENT => true));
       $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
   } catch(Exception $e) {
       echo 'Error connecting to the database.';
   }

     $stmt = $conn->prepare('INSERT INTO klant (achternaam, voornaam) VALUES (:achternaam, :voornaam)');
     $stmt->bindValue(':achternaam', $achternaam);
     $stmt->bindValue(':voornaam', $voornaam);
     $stmt->execute();
}