- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在一个表单中有多个复选框,例如:
用户可以选择一个、两个、三个或全部。第一次,我尝试只选择一个或两个选项,当我处理脚本时出现错误语句 -> "Undefined index for car", "Undefined index for boat”对于我没有检查的选项。所以我用谷歌搜索并找到了这个脚本的答案:(对于插入脚本)
$car = (isset($_POST['car']))?$_POST['car']:NULL;
$bike = (isset($_POST['bike']))?$_POST['bike']:NULL;
$plane = (isset($_POST['plane']))?$_POST['plane']:NULL;
$boat = (isset($_POST['boat']))?$_POST['boat']:NULL;
$walk = (isset($_POST['walk']))?$_POST['walk']:NULL;
它工作得很好,但是当我想用这个脚本更新我的表单时:(更新/编辑表单)
if(isset($_POST['save'])) {
include('connection.php');
$car = (isset($_POST['car']))?$_POST['car']:NULL;
$bike = (isset($_POST['bike']))?$_POST['bike']:NULL;
$plane = (isset($_POST['plane']))?$_POST['plane']:NULL;
$boat = (isset($_POST['boat']))?$_POST['boat']:NULL;
$walk = (isset($_POST['walk']))?$_POST['walk']:NULL;
$update = mysql_query("UPDATE information SET(
car = (isset($_POST['car']))?$_POST['car']:NULL;
bike = (isset($_POST['bike']))?$_POST['bike']:NULL;
plane = (isset($_POST['plane']))?$_POST['plane']:NULL;
boat = (isset($_POST['boat']))?$_POST['boat']:NULL;
walk = (isset($_POST['walk']))?$_POST['walk']:NULL;
)")
有一个错误,引号被标记了,所以我把它改成这个脚本:(修复引号标记)
if(isset('$_POST[save]')) {
include('connection.php');
$car = (isset('$_POST[car]'))?'$_POST[car]':NULL;
$bike = (isset('$_POST[bike]'))?'$_POST[bike]':NULL;
$plane = (isset('$_POST[plane]'))?'$_POST[plane]':NULL;
$boat = (isset('$_POST[boat]'))?'$_POST[boat]':NULL;
$walk = (isset('$_POST[walk]'))?'$_POST[walk]':NULL;
$update = mysql_query("UPDATE information SET(
car = (isset('$_POST[car]'))?'$_POST[car]':NULL;
bike = (isset('$_POST[bike]'))?'$_POST[bike]':NULL;
plane = (isset('$_POST[plane]'))?'$_POST[plane]':NULL;
boat = (isset('$_POST[boat]'))?'$_POST[boat]':NULL;
walk = (isset('$_POST[walk]'))?'$_POST[walk]':NULL;
)")
if($update){
echo 'Update Success! ';
echo '<a href="index.php">Results</a>';
}else{
echo 'Failed To Update! ';
echo '<a href="index.php">Home</a>';
}
}else{
echo '<script>window.history.back()</script>';
仍然有错误的“Undefined index”,但后来我也从 stackoverflow 找到了一个解决方案,如下所示:
function checkbox_value($name) {
return (isset($_POST[$name]) ? 1 : 0);
}
$sql = 'UPDATE table SET '.
'checkbox1 = '. checkbox_value('checkbox1') .','.
'checkbox2 = '. checkbox_value('checkbox2') .','.
'checkbox3 = '. checkbox_value('checkbox3') .','.
'checkbox4 = '. checkbox_value('checkbox4') .','.
'checkbox5 = '. checkbox_value('checkbox5') .','. "LIMIT 1";
我已经对这个/像这样进行了更改:
function checkbox_value($update) {
return (isset($_POST[$update]) ? 1 : 0);
}
$update = 'UPDATE information SET '.
'car = '. checkbox_value('car') .','.
'bike = '. checkbox_value('bike') .','.
'plane = '. checkbox_value('plane') .','.
'boat = '. checkbox_value('boat') .','.
'walk = '. checkbox_value('walk') .','. "LIMIT 1";
“ undefined index ”已消失,但无法更新数据。这里有点困惑...任何人都可以给我一个建议。非常感谢您的麻烦。
最佳答案
您的原始代码容易受到 SQL injection attacks 的攻击.
并且您的 checkbox_value()
版本有语法错误:
'walk = '. checkbox_value('walk') .','. "LIMIT 1";
^^^^
这将产生 sql 片段
walk = 1,LIMIT 1
^---
这是无效的。如果您修复此问题,请注意它没有 WHERE
子句:您将只更新此表中的第一条记录,这可能不是您想要的。
由于您没有提到由于该错误而从数据库中获取任何错误,因此您可能根本没有进行任何错误检查。至少,你应该有类似的东西
$result = mysqli_query($con, $sql) or die(mysqli_error($con));
^^^^^^^^^^^^^^^^^^^^^^^^^^^
永远不要假设数据库操作会成功。始终假设值(value),检查失败,并将成功视为惊喜。
关于php - 编辑模式下的多个复选框 : Undefined index,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28327878/
我只是有一个更琐碎的问题。 为什么undefined == undefined 返回true,而undefined >= undefined 为false? undefined 等于 undefine
用PHP 7.2编写套接字服务器。根据Firefox 60中的“网络”选项卡,服务器的一些HTTP响应的第一行随机变为undefined undefined undefined。因此,我尝试记录套接字
在 JavaScript 中这是真的: undefined == undefined 但这是错误的: undefined <= undefined 起初我以为<=运算符包含第一个,但我猜它试图将其转换
在回答这个问题 (Difference between [Object, Object] and Array(2)) 时,我在 JavaScript 数组中遇到了一些我以前不知道的东西(具有讽刺意味的
来自https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/of , Note: thi
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
当我添加 到我的 PrimeFaces Mobile 页面,然后我在服务器日志中收到以下警告 WARNING: JSF1064: Unable to find or serve resource, u
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我正在运行 PHP 脚本并继续收到如下错误: Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php
我是一名优秀的程序员,十分优秀!