0

簡単なコメントシステムを作っています。ページをリロードすると、最初に挿入されたコメントが複製されます。ヘッダーを使用して request_uri でリダイレクトする必要がありますか? 私はそれをしました、そしてそれはヘッダーループになりました。前もって感謝します

public function comment($username, $comment, $code)
        {
            if(!empty($username) && !empty($comment) && !empty($code))
            {
                $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 "iets gaat mis met inserten";
                }
            }
            else
            {
                echo "missing fields";
            }
        }

public function retrieve()
                {
                    if($retrieve = $this->db->query("SELECT username, comment, time FROM reviews ORDER BY id LIMIT 0, 5"))
                    {
                            while($row = $retrieve->fetch_assoc())
                            {
                                $output .= '<div class="comment">';
                                $output .= '<div class="name">'.$row['username'].'</div>';
                                $output .= '<div class="date">Added at '.date('H:i \o\n d M Y',strtotime($row['time'])).'"></div>';
                                $output .= '<p>'.$row['comment'].'</p>';
                                $output .= '</div>';
                            }
                            return $output;

                    }

                }

<?php
$reizen= new reizen;
echo $reizen->retrieve();
?>
<script type="text/javascript">
</script>
<?php
$output = '';
$output .= '<div id="contactform">';
$output .= '<form name="form" id="form" action="index.php?page=review" method="post">';
$output .= '<label>Name:</label>';
$output .= '<input type="text" name="username" />';
$output .= '<label>comment</label>';
$output .= '<textarea name="comment" rows="20" cols="20"></textarea>';
$output .= '<label><img src="captcha.php"></label>';
$output .= '<input type="text" name="code">';
$output .= '<input type="submit" class="submit" name="submit" value="Send message" />';
$output .= '</form>';
$output .= '</body>';
$output .= '</div>';
$output .= '</html>';
echo $output;
if(isset($_POST['submit']))
{
  $username = $_POST['username'];
  $comment = $_POST['comment'];
  $code = $_POST['code'];
  $reizen->comment($username, $comment, $code);
}
?>
4

1 に答える 1

-1

$input をどのように表示するかについてのヒントを教えてください。

また、重複とは、html の重複またはフォームに同じコメントが含まれていることを意味しますか? その場合は、コメントを送信する入力に attr autocomplete="false" を追加して、それを回避できます。

データベースも複製されているためです。次に、フォームのワークフローを見せてください。コメント関数を2回呼び出しているところもあります..

ユーザーが同じ投稿に対してまったく同じコメントを 2 回言うことができないように、ユーザー名、post_id、comment の両方に一意のキーを配置することをお勧めします。現在の状況によると、コードが同じコメントを2回再送信しようとすると、この一意のキーがエラーを発生させ、それが発生したときにIDを取得できます。


デバッグ用


-問題が発生したときにエラーを発生させるのにも役立つ一意のキートリックを実行します。

-u は、ページの最後で comment() 関数を呼び出しています.. および取得関数BEFOREIT

したがって、古いコメントをすべて読み込んでから、そのコメントを追加して(更新しない限り表示されません)if($_POST['submit'])、データベースからすべてのコメントを呼び出す前にその移動を修正します

于 2013-02-23T15:32:32.587 に答える