0

我正在创建一个小型评论系统,它将所有评论显示在彼此之上。问题是每次我按下提交按钮时,数据库中添加的第一行都是重复的。这导致显示很多相同的评论。我已经尝试使用标题并退出,但这也没有成功。可能与表单操作有关吗?提前致谢。

public function comment($username, $comment)
{
    if (!empty($username) && !empty($comment)) {
        $date = date("Y-m-d H:i:s");
        if ($insert = $this->db->prepare("INSERT INTO reviews (username, comment, time) VALUES (?, ?, ?)")) {
            $insert->bind_param('sss', $username, $comment, $date);
            $insert->execute();
        } else {
            echo "something is wrong with the query";
        }
    } else {
        echo "missing fields";
    }
}

这是用法,表单在此下方回显,如您所见,我重定向以避免重复然后退出

$reizen = new reizen;
if (isset($_POST['submit'])) {
    $username = $_POST['username'];
    $comment  = $_POST['comment'];
    header("Location: index.php?" . $_SERVER['QUERY_STRING']);
    $reizen->comment($username, $comment);
    exit();
}
echo $reizen->retrieve();
4

1 回答 1

0

您需要使用POST/REDIRECT/GET 模式来防止这种情况。

于 2013-02-24T17:39:28.857 回答