我正在寻找一些问题的帮助我试图将数组中的值分别注入到MySQL表中。所以,不是一行中的整个数组,而是单独的条目。
表格是这样的:
<form <form class="reg" name="main_form" action="form.php" method="post">>
<ul>
<li>
<label for="text1">
<input type="checkbox" name="task[]" value="text1" />text1
</label>
</li>
<li>
<label for="text2">
<input type="checkbox" name="task[]" value="text2" />text2
</label>
</li>
<li>
<label for="text3">
<input type="checkbox" name="task[]" value="text3" />text3
</label>
</li>
</ul>
<input type="submit" value="submit" />
</form>
在form.php中我现在有类似的东西可以将所有选中的框放到表格中的一行:
<?php
require 'db/config.php';
$link = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD);
if (!$link){
die('Could not connect due to: ' . mysql_error());
}
$db_selected = mysql_select_db(DB_NAME, $link);
if (!$db_selected){
die('Can\'t use: ' . DB_NAME . ': ' . mysql_error());
}
$task = implode (PHP_EOL, $_POST['task']);
$sql = "INSERT INTO completed (task) VALUES ('$task')";
if (!mysql_query($sql)){
die('Error: ' . mysql_error());
}
mysql_close();
?>
如果有人进来并选中所有三个复选框(text1,2&amp; 3),我需要将其作为三个单独的条目输入到数据库中,而不是作为一个组合在一起。
我认为我需要在表格实际将它们输入数据库之前使用像explode()这样的东西,但我并不是100%肯定。任何帮助将不胜感激。
答案 0 :(得分:1)
您的固定版本,但您的api 已弃用,您的方法不是sql注入保存。 不要使用这种方法使用更好的方法,我在后面的回答中提到过。
替换此
$task = implode (PHP_EOL, $_POST['task']);
$sql = "INSERT INTO completed (task) VALUES ('$task')";
if (!mysql_query($sql)){
die('Error: ' . mysql_error());
}
用这个
<?php
foreach ($_POST['task'] as $task) {
$sql = "INSERT INTO completed (task) VALUES ('$task')";
if (!mysql_query($sql)){
die('Error: ' . mysql_error());
}
}
使用较新的Api保存版本因为不推荐使用mysql_connect,并且sql注入保存。所以使用新的mysqli api。为了防止SQL注入你应该准备好语句,会在一分钟内更新我的答案。 不要使用其他方法。原因mysql_connect不仅被弃用,它在api最近的php版本中删除了。感谢@vove的通知。
<?php
require 'db/config.php';
$mysqli = new mysqli(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);
if ($mysqli->connect_error) {
die('Connect Error (' . $mysqli->connect_errno . ') '
. $mysqli->connect_error);
}
$stmt = $mysqli->prepare("INSERT INTO completed (task) VALUES (?)");
if (!$stmt) {
echo $mysqli->error;
exit();
}
foreach ($_POST['task'] as $task) {
$stmt->bind_param("s", $task);
$stmt->execute();
}
$stmt->close();
$mysqli->close();
选择了text1和text2。
mysql> select * from completed;
+-------+
| task |
+-------+
| text1 |
| text2 |
+-------+