В этом модуле мы изучим основы работы с формами в PHP и обработку POST-запросов. Вы научитесь получать данные, отправленные пользователем, проверять метод запроса и безопасно выводить информацию. POST-запросы используются для отправки конфиденциальных данных (паролей), больших объемов текста или загрузки файлов, так как данные не отображаются в адресной строке браузера.
Вам предстоит выполнить ряд заданий: от различения методов GET и POST до написания полноценных сценариев обработки форм. Будьте внимательны к синтаксису суперглобальных массивов и правилам написания ключей. Удачи!
- Модуль 1: Основы синтаксиса PHP
- Модуль 2: Переменные и типы данных
- Модуль 3: Операторы
- Модуль 4: Условные конструкции
- Модуль 5: Циклы
- Модуль 6: Массивы
- Индексированные массивы.
- Ассоциативные массивы.
- Многомерные массивы.
- Добавление элементов в массив.
- Удаление элементов из массива.
- Функция count().
- Функция array_push() и array_pop().
- Функция array_shift() и array_unshift().
- Функция array_merge().
- Функция array_slice().
- Функция array_splice().
- Функция in_array().
- Функция array_search().
- Функция array_keys() и array_values().
- Функция array_unique().
- Функция array_reverse().
- Сортировка: sort(), rsort().
- Сортировка: asort(), arsort().
- Сортировка: ksort(), krsort().
- Функция array_map().
- Функция array_filter().
- Функция array_reduce().
- Функция array_walk().
- Функция array_column().
- Деструктуризация массивов.
- Iterator интерфейс
- Модуль 7: Функции
- Объявление функций.
- Вызов функций.
- Параметры функций.
- Возврат значений return.
- Значения параметров по умолчанию.
- Передача по значению.
- Передача по ссылке.
- Переменное количество аргументов.
- Оператор распаковки ....
- Типизация параметров.
- Типизация возвращаемых значений.
- Nullable типы.
- Union типы (PHP 8).
- Именованные аргументы (PHP 8).
- Анонимные функции.
- Стрелочные функции.
- Замыкания и use.
- Рекурсивные функции.
- Глобальные переменные в функциях.
- Статические переменные в функциях.
- IteratorAggregate интерфейс
- Модуль 8: Работа со строками
- Одинарные и двойные кавычки.
- Экранирование символов.
- Heredoc и Nowdoc синтаксис.
- Функция strlen().
- Функция substr().
- Функция str_replace().
- Функция strpos() и strrpos().
- Функция explode() и implode().
- Функция trim(), ltrim(), rtrim().
- Функция strtolower() и strtoupper().
- Функция ucfirst() и ucwords().
- Функция str_repeat().
- Функция htmlspecialchars().
- Модуль 9: Суперглобальные переменные
- Модуль 10: Работа с формами
- Обработка GET-запросов.
- Обработка POST-запросов.
- Валидация текстовых полей.
- Валидация email.
- Валидация чисел.
- Модуль 11: Работа с файлами
- Модуль 12: Дата и время
- Модуль 13: Регулярные выражения
- Модуль 14: Сессии и Cookie
- Модуль 15: Include и Require
- Модуль 16: Объектно-ориентированное программирование
- Модуль 17: Пространства имен
- Модуль 18: Обработка ошибок и исключений
- Модуль 19: Работа с JSON и XML
- Модуль 21: PDO - PHP Data Objects
- Модуль 22: Composer и зависимости
- Модуль 23: cURL и HTTP запросы
- Модуль 24: REST API
- Модуль 25: Безопасность
- Модуль 28: Работа с изображениями
- Модуль 29: Отправка email
- Модуль 30: Паттерны проектирования
- Модуль 31: Тестирование
- Модуль 32: Продвинутые возможности PHP 8+
1. GET или POST?
Распределите характеристики по методам передачи данных. Вспомните, какой метод используется для передачи ссылок, а какой — для отправки паролей.
2. Получение данных из формы
Заполните пропуски, чтобы получить значение поля ввода с именем login из суперглобального массива POST и вывести его.
// HTML: <input type="text" name="login">
$user_login = input1S[input2S];
echo "Вы вошли как: " . input3S;3. Проверка метода запроса
Соберите условие, которое проверяет, была ли форма отправлена методом POST. Используйте данные из банка.
if (input1S[input2S] === input3S) {
echo "Форма отправлена!";
}4. Исправьте ошибки в обработчике
В коде допущены синтаксические ошибки при работе с массивом POST. Найдите и исправьте их. Обратите внимание на написание суперглобальной переменной и использование ключей.
<?php// Получаем email из формы$email = $POST['user_email'];// Получаем сообщение$message = $_POST[message];echo $email . ": " . $message;?>5. Ключи массива POST
Посмотрите на HTML-код формы и PHP-обработчик. Что выведет этот код при отправке формы?
<form method="POST">
<input type="text" name="city" id="user_city" value="Paris">
</form>
echo $_POST['user_city'] ?? 'Ошибка';
6. Элементы формы и PHP
Сопоставьте HTML-атрибуты формы с тем, как они интерпретируются или используются в PHP.
name="username"action="handler.php"method="POST"value="Ivan"7. Безопасный вывод данных
Соберите скрипт, который принимает имя пользователя и безопасно выводит его, защищаясь от XSS-атак (внедрения HTML-тегов).
$name = $_POST['name'];$safe_name = htmlspecialchars($name);echo "Привет, " . $safe_name;echo "Привет, " . $name;$safe_name = strip_tags();8. Логика обработки формы
Восстановите правильный порядок блока кода, который проверяет, была ли нажата кнопка отправки, и если да, то обрабатывает данные. Если нет — выводит сообщение.
echo "Пожалуйста, отправьте форму.";} $data = $_POST['text'];} else { echo "Обработано: " . $data;if (isset($_POST['submit_btn'])) {9. Калькулятор суммы
Представьте, что пользователь заполнил форму числами 5 и 10. Посчитайте, что выведет скрипт.
// Пользователь отправил: a=5, b=10
$a = $_POST['a'];
$b = $_POST['b'];
$sum = $a + $b;
echo "Total: " . $sum;