0

下面的代码有什么问题。错误警告:为 foreach() 提供的参数无效

    if(isset($_POST['submit']))
        {
        foreach($_POST['team[]'] as $value)
        {
        $insert=mysql_query("INSERT INTO team('team') VALUES ('$value')");
        }
        if($insert)
        {
        echo "dONE";
        }
        }
<form method="post" action="check.php">
<input type="checkbox" name="team[]" value="AG"> Argentina
<input type="checkbox" name="team[]" value="GE"> Germany
<input type="checkbox" name="team[]" value="BR"> Brazil
<input type="submit" name="submit" value="submit">
</form>
4

5 回答 5

2

尝试:

foreach($_POST['team'] as $value)
于 2012-07-31T15:28:07.133 回答
1

不要参考team[]。而是使用

if (isset($_POST['team'])) {
    foreach($_POST['team'] as $value) { ... }
}
于 2012-07-31T15:28:28.643 回答
1

当您从 $_POST 收到变量 team 时,它将是每个复选框的数组。

因此,team[]您应该使用而不是使用

foreach($_POST['team'] as $value)

另外,您应该知道,如果没有选中任何复选框,则关键团队将不存在,因此请确保在您的 foreach 之前执行if (isset($_POST['team']))

每次循环时,您都会覆盖插入。

你可能想做这样的事情:

if(isset($_POST['submit']))
{
    if (isset($_POST['team']))
    {
        $insert = true;

        foreach($_POST['team'] as $value)
        {
            // we add security with mysql_real_escape_string
            $value = mysql_real_escape_string($value);
            $result = mysql_query("INSERT INTO team('team') VALUES ('$value')");

            if (!$result)
            {
                $insert = false;
                break;
            }
        }

        if($insert)
        {
            echo "dONE";
        }
    }
}

您可能需要检查mysql_real_escape_string为您的代码添加安全性

于 2012-07-31T15:30:59.590 回答
0

当您name=something[]输入时,php 将为您创建数组,因此您只需要执行

foreach($_POST['team'] as $value)

name=team[member][]可以像这样在php中迭代类似的东西

foreach($_POST['team']['member'] as $value)

因此,它使分组输入和处理多个动态输入变得非常容易

于 2012-07-31T15:28:44.933 回答
0

尝试以下操作:

$teams = $_POST['team'];
$submitted = $_POST['submit'];

if(isset($submitted) && is_array($teams)) {

     foreach($teams as $team) {
          /* Escapes special characters in a string for use in an SQL statement */ 
          $team = mysql_real_escape_string($team)
          $insert = mysql_query("INSERT INTO team('team') VALUES ('$team')");
     }

     if($insert) {
          echo "dONE";
    }
} else {
    echo "Either Form Not Submitted or Teams is Not Array";
}
于 2012-07-31T15:30:14.350 回答