gpt4 book ai didi

php - 使用 PHP 和复选框更新 MySQL 表

转载 作者:行者123 更新时间:2023-11-30 23:17:06 26 4
gpt4 key购买 nike

我有一个名为 products 的表,其中包含:

id:int,主键,自增product_name:varchar突出显示:int(1 或 0)

所以,我希望突出显示的字段可以通过我的管理页面完全更新,所以每当我获得每个产品(或行)的数据时,我都会在产品名称旁边有一个复选框,指示它是否突出显示 (1) 或 ( 0).

这是我的代码:

<?php
$host = "localhost";
$user = "root";
$pass = "usbw";
$db = "test";

mysql_connect($host,$user,$pass);
mysql_select_db($db);
?>

<?php

if(isset($_POST['submit']))
{
foreach (isset($_POST['checkBox']) as $id => $value)
{
mysql_query("UPDATE products SET highlighted='$value' WHERE id='$id'");
}
echo "Updated! <a href='index.php'>Back</a>";
}
else
{
echo "<form action='index.php' method='POST'>";
$result = mysql_query("SELECT * FROM products");
while($q = mysql_fetch_assoc($result))
{
echo "".$q['product_name']."";
if($q['highlighted'] == '1')
{
echo "<input type='checkbox' checked value='1' name='checkBox['"; ?><?php echo $q['id']; ?><?php echo "']'>";
}
else
{
echo "<input type='checkbox' value='1' name='checkBox['"; ?><?php echo $q['id']; ?><?php echo "']'>";
}
echo "<br>";
}

echo "<input type='submit' value='submit' name='submit'>";
echo "</form>";
}

?>

出于某种原因,每当我尝试更新表单时都会收到以下错误:

Warning: Invalid argument supplied for foreach() in C:\Users\Badsector\Desktop\USBWebserver v8.5\8.5\root\teszt\index.php on line 15

提前感谢您的帮助,我现在完全糊涂了,我已经挣扎了几个小时了!

最佳答案

改变

foreach (isset($_POST['checkBox']) as $id => $value)

foreach ($_POST['checkBox'] as $id => $value)

isset() 返回一个 bool 值,foreach 需要一个数组。

你也容易被mysql注入(inject)。

关于php - 使用 PHP 和复选框更新 MySQL 表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17138788/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com