php - 复选框插入 MySql 数据库

标签 php mysql checkbox insert-statement

我有一个调查类型的表格,在许多问题中,用户可以选择勾选多个框。

我将这些答案存储在 mysql 数据库中,但是目前,数据库只存储最后一个勾选的复选框。无论如何存储所有检查的值,可能用逗号或分号分隔?

这是我的代码:

        $q1 = mysql_escape_string($_POST['q1']);
        $q2 = mysql_escape_string($_POST['q2']);
        $q3 = mysql_escape_string($_POST['q3']);            
        $q4 = mysql_escape_string($_POST['q4']);
        $q5 = mysql_escape_string($_POST['q5']);            
        $q6 = mysql_escape_string($_POST['q6']);
        $q7 = mysql_escape_string($_POST['q7']);
        $q8 = mysql_escape_string($_POST['q8']);
        $q9 = mysql_escape_string($_POST['q9']);
        $q10 = mysql_escape_string($_POST['q10']);
        $q11 = mysql_escape_string($_POST['q11']);
        $q12 = mysql_escape_string($_POST['q12']);
        $q13 = mysql_escape_string($_POST['q13']);
        $q14 = mysql_escape_string($_POST['q14']);
        $email = mysql_escape_string($_POST['email']);

        require_once('connection.php');

        $sql="INSERT INTO survey (Question1, Question2, Question3, Question4, Question5, Question6, Question7, Question8, Question9, Question10, Question11, Question12, Question13, Question14, eMail) VALUES ('$q1', '$q2', '$q3', '$q4', '$q5', '$q6', '$q7', '$q8', '$q9', '$q10', '$q11', '$q12', '$q13', '$q14', '$email')";

        if (!mysql_query($sql,$conn))
          {
      die('Error: ' . mysql_error());
          }

          mysql_close($conn);

最佳答案

首先,mysql_escape_string 已贬值 - 您应该使用 mysql_real_escape_string。

其次,这将允许任何恶意的人在结果中插入不同的值,例如 2 和 3。您需要使每个值都符合 0 或 1。为此,我建议您先转换为 bool,然后再转换为 int:

$q1 = (int)((bool)$_POST['q1']);
$q2 = (int)((bool)$_POST['q2']);
...

对于您的 HTML,每个复选框都需要一个值为“1”的值属性。

因为它们只是整数,所以没有必要对它们进行转义。

关于php - 复选框插入 MySql 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3831522/

相关文章:

php - 无法添加或更新子行外键约束失败 mysql 错误号 : 1452

php - 查询3个表的数据

mysql - 高分表 - 如何获得每个用户的最高分?

mysql - 更新时无法从表中获取id

php - HTML 复选框和表单中的单一输入

jquery - 如何从表排序器中选择所有复选框

javascript - JS 复选框启用/禁用输入

php - php中的TreeView目录结构

php - 对动态添加的元素所做的更改会自动恢复

php - WordPress 元值查询不起作用