Утверждение пользователем по электронной почте с выводом результатов, но без обновления записей в базе данных

В настоящее время я работаю над проектом, в котором мне нужно заставить пользователя зарегистрироваться, а затем на адрес электронной почты администратора веб-сайта отправляется электронное письмо со ссылкой для утверждения (содержащей php-страницу ниже, электронную почту пользователя и sha512). Когда нажимается ссылка утверждения, она предназначена для обновления таблицы с соответствующим адресом электронной почты и изменением isApproved на 1, но ничего не делает, кроме печати эха.

Я попытался изменить команды SQL, добавив ` вокруг имен, поискав их на w3schools, stackoverflow и других форумах, но ничего не нашел.

<?php
    $hash = $_GET['h'];
    $email = $_GET['e'];

    if ($hash == hash('sha512', 'ACCEPT')){
    $host = "redacted";
    $dbUsername = "redacted";
    $dbPassword = "redacted";
    $dbname = "redacted";
    //create connection
    $conn = mysqli_connect($host, $dbUsername, $dbPassword, $dbname);
    if (mysqli_connect_error()) 
    {
        die('Connect Error('. mysqli_connect_errno().')'.mysqli_connect_error());
    } 
    else 
    {
        $sql = "UPDATE `User` SET `isApproved`='1' WHERE `User`.`email`=$email";
        echo("approved");
    }
?>

Все, что я вижу при открытии веб-сайта, «одобрено», чего я и ожидал, но записи в базе данных остаются неизменными.

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
42
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Я думаю, вы не выполнили команду выполнения.

    $conn = mysqli_connect($host, $dbUsername, $dbPassword, $dbname);
    ....
    $sql = "UPDATE `User` SET `isApproved`='1' WHERE `User`.`email`=$email";
    $stmt = mysqli_prepare($conn, $sql);
    mysqli_stmt_execute($stmt);

Предупреждение: mysqli_execute() ожидает, что параметр 1 будет mysqli_stmt

Jelon51 27.05.2019 18:01

Все еще говорит, что ожидает stmt как параметр 1

Jelon51 27.05.2019 18:08
Ответ принят как подходящий

Это потому, что вы не выполняете оператор запроса.

$sql = "UPDATE `User` SET `isApproved`='1' WHERE `User`.`email`=$email"; — это запрос, который вы написали, но не выполнили. Вам нужно выполнить его, используя метод mysqli_query(), передавая соединение и запрос в параметрах mysqli_query($conn, $sql);. Вы можете прочитать больше об этом здесь.

Обновленный код:

   <?php
        $hash = $_GET['h'];
        $email = $_GET['e'];
    
        if ($hash == hash('sha512', 'ACCEPT')){
        $host = "redacted";
        $dbUsername = "redacted";
        $dbPassword = "redacted";
        $dbname = "redacted";
        //create connection
        $conn = mysqli_connect($host, $dbUsername, $dbPassword, $dbname);
        if (mysqli_connect_error()) 
        {
            die('Connect Error('. mysqli_connect_errno().')'.mysqli_connect_error());
        } 
        else 
        {
            $sql = "UPDATE `User` SET `isApproved`='1' WHERE `User`.`email`=$email";
            mysqli_query($conn, $sql); // <------- Run SQL Query 
            echo("approved");
        }
    ?>

Можете ли вы поделиться структурой вашей таблицы?

Javapocalypse 27.05.2019 18:10

Код работает нормально. Проблема скорее всего в запросе. Попробуйте выполнить следующий запрос. $sql = "UPDATE User SET isApproved=1 WHERE User.email=$email;";

Javapocalypse 27.05.2019 18:30

еще ничего :/

Jelon51 27.05.2019 18:36

Интересно, почему он не выполняется. Попробуйте $sql = "UPDATE User SET isApproved=1 WHERE email=$email;";

Javapocalypse 27.05.2019 18:37

К сожалению, по-прежнему ничего, все выполняется, кроме фактического изменения дабатазы.

Jelon51 27.05.2019 18:41

Это работает, просто вам нужно выбрать пользователя, используя первичный ключ, а не только данные таблицы.

Jelon51 27.05.2019 22:51

Прохладный! Рад, что это сработало. Отклонение редактирования, поскольку в коде ничего не меняется, кроме запроса, поскольку ранее не было строки с данным условием. Удачного кодирования :)

Javapocalypse 27.05.2019 22:57

Другие вопросы по теме