Как предотвратить добавление данных в базу данных localhost после refre sh? - PullRequest
0 голосов
/ 04 мая 2020

Я сейчас пытаюсь загрузить данные в базу данных, что я успешно сделал. Затем он отображается на editPage. php и у меня есть возможность удалить любые данные, которые были введены в базу данных. Проблема заключается в том, что каждый раз, когда я удаляю строку данных из базы данных, моя страница обновляется, и те же данные снова вводятся обратно в базу данных. Как я могу предотвратить это?

Вот мой editPage. php, который позволяет вставлять, просматривать и удалять данные.

<?php
session_start();

$connect = mysqli_connect("localhost", "root", "", "skilltask2");

if ($_SESSION["loggedin"] == false) {
    header('Location: skillsTask2.php');
}
if(isset($_POST['content']) || isset($_POST['header']) || isset($_POST['image'])){
    $displayText = $_POST['content'];
    $displayHeader = $_POST['header'];
    $dir="images/";
    $file=$dir.basename($_FILES["image"]["name"]);
    $query = "INSERT INTO `content` (`image`) VALUES ('$file')";
    if(strlen($displayText)>0){
        $query = "INSERT INTO `content` (`text`, `header`, `image`) VALUES ('$displayText', '$displayHeader', '$file')";
    }

    if (mysqli_query($connect, $query)) {
        echo '<script>alert("Title, Text and Image has been uploaded to database")</script>';
    }
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>Edit Page</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.0/jquery.min.js"></script>
    <link rel="stylesheet" href="editPage.css">
    <script>
        function deleteContent(id,header) {
            var xhr = new XMLHttpRequest();
            xhr.open("GET", "processDelete.php?id="+id, true);
            xhr.send();
            alert("You have deleted "+header);
            location.reload();
        }
    </script>
</head>
<body>
    <br>
    <br>
    <div class="container" style="width:25vw;">
        <h3 align="center">Update and Insert Headers, Text and Images</h3>
        <br>
        <form method="post" enctype="multipart/form-data">
            <h3>Title</h3>
            <input type="text" name="header" required />
            <br>
            <br>
            <h3>Text</h3>
            <input type="text" name="content" required />
            <br>
            <br>
            <h3>Image</h3>
            <input type="file" name="image" required />
            <br>
            <br>
            <br>
            <input type="submit" name="all" value="Upload All" />
        </form>
        <br>
        <br>
        <?php
            echo "<a href=\"skillsTask2.php\">Logout</a>";
        ?>
    </div>
    <div id="rightSide">
        <?php
                    $conn = mysqli_connect("localhost", "root", "", "skilltask2");
                    $query = "SELECT * FROM content ORDER BY `id` DESC";  
                    $result = mysqli_query($connect, $query); 
                        while($row = mysqli_fetch_array($result))   {  
                        $theimage = $row['image'];
                        $theheader = $row['header'];
                        $thetext = $row['text'];
                        $id = $row['id'];
                         echo "<div id='card'>
                                <img src=\"".$theimage."\" >
                                <div id='cardHeader'>
                                    <b>$theheader</b><br>$thetext
                                </div>
                                <button onclick=deleteContent($id,'$theheader')>Delete</button>
                        </div>
                        ";
                        }
        ?>
    </div>
</body>
</html>

А вот мой processDelete. php страница, которая удаляет строки кода из базы данных.

<?php
    session_start();
    $connect = mysqli_connect("localhost", "root", "", "skilltask2");
    $id=$_GET['id'];
    $query = "DELETE FROM content WHERE id=$id"; 
    $result = mysqli_query($connect,$query) or die ( mysqli_error());
?>

Надеюсь, вы можете помочь. Еще раз спасибо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...