@Malodushniy

Почему введёные данные о заказе не отправляются в таблицу Mysql?

Это код отправки введенных данных в таблицу Mysql :

<p align="center"><input type="submit" name="order" value="Заказать" /></p>

</form>

<?
}
if($_SESSION['cart'] && isset($_POST['order']))
{
foreach ($_POST as $ArrKey => $ArrStr) {
$ArrKey = $_POST[$ArrKey];
}
$date = date('Y-m-d');
$time = date('H:i:s');

foreach($_SESSION['cart'] as $id => $quantity):
$product = get_product($id);
$query = mysql_query("INSERT INTO orders(name,s_name,address,post_index,email,date,time,product,prod_id,price,qty) VALUES ('$name','$s_name','$address','$post_index','$email','$date','$time','{$product['title']}','{$product['id']}','{$product['price']}','$quantity')");
endforeach;

echo "<p align='center' style='color: #fff;'>Ваш заказ успешно принят! Спасибо за покупку!</p>";
}
?>


Скриншот страницы заказа, все, что вбивается вручную на базу не отправляется, помогите с кодом пожалуйста. 5e56119fd54f2638157924.png
  • Вопрос задан
  • 184 просмотра
Решения вопроса 1
nokimaro
@nokimaro Куратор тега PHP
Проблема в том что нужно данные взять из $_POST
Например так
$name = isset($_POST['name']) ? $_POST['name'] : '';


Удачи вам в изучении программирования
Для работы с БД настоятельно рекомендую ознакомиться и сразу использовать хотя бы это mysqli + prepared statements
https://www.php.net/manual/ru/mysqli.quickstart.pr...
https://www.php.net/manual/ru/pdo.prepared-stateme...
https://www.w3schools.com/php/php_mysql_prepared_s...

<h2 align="center">Оформление заказа</h2>

<?
if($_SESSION['cart'] && !isset($_POST['order']))
{

    ?>
    <form action="index.php?view=order" method="post" id="cart-form">

        <table id="mycart" align="center" cellspacing="0" cellpadding="0" border="0">
            <tr>
                <th>Товар</th>
                <th>Цена</th>
                <th>Кол-во</th>
                <th>Всего</th>
            </tr>

            <? foreach($_SESSION['cart'] as $id => $quantity):
                $product = get_product($id);

                ?>

                <tr>
                    <td align="center"><?= $product['title']; ?></td>
                    <td align="center">$<?= number_format($product['price'], 2); ?></td>
                    <td align="center"><?= $quantity; ?></td>
                    <td align="center">$<?= number_format($product['price'] * $quantity, 2); ?></td>
                </tr>
            <?endforeach; ?>

        </table>
        <p class="total" align="center">Общая сумма заказа:
            <span class="product-price"><?= number_format($_SESSION['total_price'], 2); ?> $</span></p>

        <p align="center" style="color: #fff;">
            Ваше имя: <br/>
            <input type="text" name="name"/><br/>
            Ваша фамилия: <br/>
            <input type="text" name="s_name"/><br/>
            Ваш адрес: <br/>
            <input type="text" name="address"/><br/>
            Почтовый индекс: <br/>
            <input type="text" name="post_index"/><br/>
            Ваше e-mail: <br/>
            <input type="text" name="email"/><br/>
        </p>


        <p align="center"><input type="submit" name="order" value="Заказать"/></p>

    </form>

    <?
}
if($_SESSION['cart'] && isset($_POST['order']))
{
    foreach($_POST as $ArrKey => $ArrStr)
    {
        $ArrKey = $_POST[$ArrKey];
    }
    $date = date('Y-m-d');
    $time = date('H:i:s');
    
    $name = isset($_POST['name']) ? $_POST['name'] : '';
    $s_name = isset($_POST['s_name']) ? $_POST['s_name'] : '';
    $address = isset($_POST['address']) ? $_POST['address'] : '';    
    $post_index = isset($_POST['post_index']) ? $_POST['post_index'] : '';    
    $email = isset($_POST['email']) ? $_POST['email'] : '';

    foreach($_SESSION['cart'] as $id => $quantity)
    {
        $product = get_product($id);
        $query = mysql_query("
            INSERT INTO orders(name,s_name,address,post_index,email,date,time,product,prod_id,price,qty) 
            VALUES 
            ('$name','$s_name','$address','$post_index','$email','$date','$time','{$product['title']}','{$product['id']}','{$product['price']}','$quantity')
        ");
    }

    echo "<p align='center' style='color: #fff;'>Ваш заказ успешно принят! Спасибо за покупку!</p>";
}
?>
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
irishmann
@irishmann
Научись пользоваться дебаггером
1. я не вижу явного подключения к БД.
2. SQL-injection. Используйте подготовленные запросы.
Ответ написан
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы
04 апр. 2020, в 21:01
35000 руб./за проект
04 апр. 2020, в 20:32
5000 руб./за проект
04 апр. 2020, в 20:30
25000 руб./за проект