Почему код не работает?

spoiler
<?php
require_once "credentials.php";

$connection = new mysqli(DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_NAME);
if($connection->connect_error) {
    die("Fatal Error");
}

if(isset($_POST['delete']) && isset($_POST['user-id'])) {
    $user_id = (int)$_POST['user-id'];
    $stmt = $connection->prepare('DELETE FROM users WHERE id = ?');
    $stmt->bind_param('i', $user_id);
    $stmt->execute();
    $stmt->close();
}

if (isset($_POST['first-name']) &&
isset($_POST['last-name']) &&
isset($_POST['age']) &&
isset($_POST['country'])) {
    $stmt = $connection->prepare("INSERT INTO users('lastName', 'firstName', 'age', 'country') VALUES(?,?,?,?)");
    $first_name = $_POST['first-name'];
    $last_name = $_POST['last_name'];
    $age = (int)$_POST['age'];
    $country = $_POST['country'];
    $stmt->bind_param('ssis', $first_name, $last_name, $age, $country);
    $stmt->execute();
    $stmt->close();
}

echo <<<_HTML
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link href="styles.css" rel="stylesheet" type="text/css">
</head>

<body>
    <form action="index.php" method="post">
        <ul>
            <li>
                <label for="fName">First Name: </label>
                <input type="text" required id="fName" name="first-name" />
            </li>
            <li>
                <label for="lName">Last Name: </label>
                <input type="text" required id="lName" name="last-name" />
            </li>
            <li>
                <label for="age">Age: </label>
                <input type="text" required id="age" name="age" />
            </li>
            <li>
                <label for="country">Country: </label>
                <input type="text" required id="country" name="country" /><br>
            </li>
            <li>
                <button type="submit">Send data</button>
            </li>
        </ul>
    </form>
_HTML;

$stmt = $connection->prepare('SELECT FROM users WHERE age BETWEEN ? AND ?');
$age_start = 20;
$age_end = 30;
$stmt->bind_param('ii', $age_start, $age_end);
$stmt->execute();
$result = $stmt->get_result();
if(!$result) {
    print("Database access failed");
} else {
    $rows = $result->num_rows;

for($j = 0; $j < $rows; $j++) {
    $row = $result->fetch_assoc();

    $r0 = htmlspecialchars($row['firstName']);
    $r1 = htmlspecialchars($row['lastName']);
    $r2 = htmlspecialchars($row['age']);
    $r3 = htmlspecialchars($row['country']);
    $r4 = $row['id'];

    echo <<<_HTML
    <p>
    <ul>
        <li>
            First Name: $r0
        </li>
        <li>
            Last Name: $r1
        </li>
        <li>
            Age: $r2
        </li>
        <li>
            Country: $r3 
        </li>
    </ul>
    <form class="delete-record" action="index.php" method="post">
        <input type="hidden" name="delete" value="yes"/>
        <input type="hidden" name="user-id" value="$r4"/>
        <button type="submit">DELETE RECORD</button>
    </form>
</p>
_HTML;
}
}


echo <<<_HTML
</body>

</html>
_HTML;

$result->free();
$stmt->close();
$connection->close();


Код, расположенный выше, выводит форму для заполнения данных (которые потом, по идее, вносятся в таблицу users), а также выводит записи из этой же таблицы ниже формы. Пишу код, как сказано в учебнике, используя подготовленные запросы, но он все равно не работает. Например, когда забиваешь данные в форму и пытаешься отправить, то кусок кода, ответственный за это, ничего не делает. Вместо этого появляется окно с сообщением "Страница недоступна":
spoiler
if (isset($_POST['first-name']) &&
isset($_POST['last-name']) &&
isset($_POST['age']) &&
isset($_POST['country'])) {
    $stmt = $connection->prepare("INSERT INTO users('lastName', 'firstName', 'age', 'country') VALUES(?,?,?,?)");
    $first_name = $_POST['first-name'];
    $last_name = $_POST['last_name'];
    $age = (int)$_POST['age'];
    $country = $_POST['country'];
    $stmt->bind_param('ssis', $first_name, $last_name, $age, $country);
    $stmt->execute();
    $stmt->close();
}


Когда тестировал обычные, неподготовленные запросы, то все работало: код успешно взаимодействовал с базой данных и выводил (или вносил) данные в таблицу.
  • Вопрос задан
  • 111 просмотров
Решения вопроса 1
@galaxy
Научитесь выводить ошибки или читать логи.

Пока скажу, что тут проблема с кавычками:
INSERT INTO users('lastName', 'firstName', 'age', 'country')....
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
FanatPHP
@FanatPHP
Чебуратор тега РНР
На будущее, вместо бессмысленной ерунды

$connection = new mysqli(DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_NAME);
if($connection->connect_error) {
die("Fatal Error");
}

Надо всегда писать

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$connection = new mysqli(DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_NAME);

ну и
mysqli_set_charset($mysqli, "utf8mb4");
заодно

Но главное - это первая строчка. После её добавления тебе база данных будет сам показывать, в каком месте запроса ошибка.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы