我在php页面上有一个开关,代码为:
<form action="onoff-switch.php" method="post">
<div class="onoffswitch">
<input type="checkbox"
name="onoffswitch"
class="onoffswitch-checkbox"
id="myonoffswitch" checked
value="on">
<label class="onoffswitch-label" for="myonoffswitch">
<div class="onoffswitch-inner"></div>
<div class="onoffswitch-switch"></div>
</label>
</div>
<input type="submit" name="formSubmit" value="Submit" />
</form>
当选中时,它应该向php页面onoff-switch.php发送一个ON或OFF值。有两个问题,不需要第15行,但是,表单不会提交任何值,除非它存在。去掉第15行,当我选中或取消选中该框时,它应该自己提交。事实并非如此。
此外,onoff-switch.php提供了一个值"OFF"的反馈,我不知道它是从哪里得到的,因为代码中没有"OFF"。当然,如果没有选中该框,则应该是该值。
问题是这个复选框哪里出了问题?
PHP代码:
<?php
$con=mysqli_connect("localhost","user","pass","db");
// Check connection
if (mysqli_connect_errno())
{
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
if (isset($_POST['formSubmit']))
{
// escape variables for security
$scanningvalue = mysqli_real_escape_string($_POST['onoffswitch']);
$sqlon="INSERT INTO configuration (scanning) VALUES ('$scanningvalue')";
$result=mysqli_query($con, $sqlon);
if($scanningvalue=='') $scanningvalue='off';
if($result)
{
echo "The db operation done (1 record added) and switch value ".$scanningvalue;
}
else
{
echo "The db operation error and switch value ".$scanningvalue;
}
}
mysqli_close($con);
?>
if($scanningvalue=='') $scanningvalue='off';
您添加了上面的代码,在查询之后,您应该在设置$scanningvalue的值之后添加它,还有一件事,不需要mysql_real_sescape_string,因为您正在设置值,并且不存在sql注入的问题。
如果想要打开/关闭,为什么不使用单选按钮而不是复选框?