";无效的参数";在发布的数组foreach循环上


"Invalid argument" on posted array foreach loop

Yo,所以我有一个简单的foreach循环:

foreach ($_POST['carID'] as $carID) 
{  
    $query = "DELETE FROM cars WHERE carIndex = ".$carID."";
    echo $query;
} 

但我得到了错误:警告:在第8行的K:''XAMPP''htdocs''Cars''deletecar.php中为foreach()提供的参数无效

第8行为:

foreach ($_POST['carID'] as $carID)

数组"($_POST['carID']"是从另一个页面上的多个复选框创建的,只需使用提交按钮表单即可发布。

形式为:

<form name="input" action="delete.php" method="POST">
    <input type="submit" value="Submit">
    <while loop>
    <input type="checkbox" name="carID[]" value="'.$row['carIndex'].'">
    <end loop>
</form>

实际的复选框位于基于mysql查询的循环中。

这里生成的数组被发送到一个页面,该页面使用foreach循环为查询创建WHERE语句来显示所选的数据库记录。完全相同的前臂现在不起作用了。

我知道:

$where = " WHERE ";    
foreach ($_POST['carID'] as $carID) 
{  
    $where = $where." carIndex = ".$carID." OR";
}
$where = substr($where, 0, -3); 

这样做非常好。

然后我有一个你确定你想删除是和否按钮。

我尝试过的是按钮只是一个正常的提交按钮:

    <form name="input" action="deletecar.php" method="POST">
        <input type="submit" value="Yes" value="'.$_POST['carID'].'">
    </form>

但在提交时,在deletecar.php页面上,我得到了错误:警告:在第8行上为K:''XAMPP''htdocs''Cars''deletecarphp中的foreach()提供的参数无效

deletecar.php的完整代码是:

<?php
$db = mysqli_connect('localhost', 'root', '', 'cdb')
      or die('Error connecting');
echo $_POST['carID'];
foreach ($_POST['carID'] as $carID) 
{  
    $query = "DELETE FROM cars WHERE carIndex = ".$carID."";
    echo $query;
} 
//header ("Location: profile.php?username=".$_SESSION['username']."")
?>

发布数据的顶部回声是"Array",据我所知,它正在获取数据,因为它知道这是一个数组。然后是禁用的重定向。

这可能很简单,但似乎无法理解。

缺少名为carID的Form元素。将其包含在form中。

更改

<form name="input" action="deletecar.php" method="POST">
    <input type="submit" value="Yes" value="'.$_POST['carID'].'">
</form>

<form name="input" action="deletecar.php" method="POST">
    <input type="hidden" name="carID" value="'.$_POST['carID'].'">
    <input type="submit" value="Yes">
</form>

首先更改您的表单发送两个值的方式以及在此表单提交中发送$_POST['carID']值的位置尝试在隐藏的中发送您的carID

<form name="input" action="deletecar.php" method="POST">
  <input type="hidden" name="carID" value="<?php echo $_POST['carID']?>">
        <input type="submit" value="Yes">
    </form>

您需要首先检查print_r($_POST['carID'])值。对于错误,您需要应用检查,并需要像一样完善您的查询

$postid = $_POST['carID'];
if(is_array($postid) && sizeof($postid) > 0) {
   foreach ($postid as $carID) 
   {  
      $query = "DELETE FROM cars WHERE carIndex = '$carID'"; //use single quote
      echo $query;
   } 
}
else {
  echo 'Something wrong with post values';
}