Этот тренажер посвящен обработке данных, передаваемых через URL, с помощью GET-запросов в PHP. Вы научитесь считывать параметры из адресной строки, проверять их наличие и безопасно выводить на страницу. Задания построены от самых основ, вроде доступа к суперглобальному массиву $_GET, до более сложных тем, таких как обеспечение безопасности с помощью `htmlspecialchars` и использование оператора нулевого слияния для значений по умолчанию. Пройдя этот набор упражнений, вы сможете уверенно работать с формами и данными из URL в своих проектах.
- Модуль 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().
- Деструктуризация массивов.
- Модуль 7: Функции
- Объявление функций.
- Вызов функций.
- Параметры функций.
- Возврат значений return.
- Значения параметров по умолчанию.
- Передача по значению.
- Передача по ссылке.
- Переменное количество аргументов.
- Оператор распаковки ....
- Типизация параметров.
- Типизация возвращаемых значений.
- Nullable типы.
- Union типы (PHP 8).
- Именованные аргументы (PHP 8).
- Анонимные функции.
- Стрелочные функции.
- Замыкания и use.
- Рекурсивные функции.
- Глобальные переменные в функциях.
- Статические переменные в функциях.
- Модуль 8: Работа со строками
- Одинарные и двойные кавычки.
- Экранирование символов.
- Heredoc и Nowdoc синтаксис.
- Функция strlen().
- Функция substr().
- Функция str_replace().
- Функция strpos() и strrpos().
- Функция explode() и implode().
- Функция trim(), ltrim(), rtrim().
- Функция strtolower() и strtoupper().
- Функция ucfirst() и ucwords().
- Функция str_repeat().
- Модуль 9: Суперглобальные переменные
- Модуль 10: Работа с формами
- Обработка GET-запросов.
- Валидация чисел.
- Модуль 11: Работа с файлами
- Модуль 12: Дата и время
- Модуль 13: Регулярные выражения
- Модуль 14: Сессии и Cookie
- Модуль 15: Include и Require
- Модуль 16: Объектно-ориентированное программирование
- Модуль 17: Пространства имен
- Модуль 18: Обработка ошибок и исключений
- Модуль 19: Работа с JSON и XML
- Модуль 20: Работа с базами данных MySQLi
- Модуль 21: PDO - PHP Data Objects
- Модуль 22: Composer и зависимости
- Модуль 23: cURL и HTTP запросы
- Модуль 24: REST API
- Модуль 25: Безопасность
- Модуль 26: Генераторы и итераторы
- Модуль 27: Reflection API
- Модуль 28: Работа с изображениями
- Модуль 29: Отправка email
- Модуль 30: Паттерны проектирования
- Модуль 31: Тестирование
- Модуль 32: Продвинутые возможности PHP 8+
Доступ к GET-параметрам
Представьте, что на ваш скрипт пришел запрос по URL `index.php?name=Alex`. Вам нужно получить значение параметра 'name'. Впишите в код правильное имя суперглобального массива, который используется для доступа к данным GET-запроса.
<?php
// URL: index.php?name=Alex
$userName = input1S['name'];
echo "Привет, " . $userName;
?>Исправьте ошибку доступа к ключу
В коде допущена распространенная ошибка при обращении к элементу ассоциативного массива. Найдите и исправьте ее. Скрипт должен вывести "Книга" на основе данных из URL.
<?php// URL: store.php?product=Книгаecho $_GET[product];?>Что выведет код?
Проанализируйте URL, указанный в комментарии, и определите, какое значение будет выведено на экран в результате выполнения этого PHP-кода.
<?php
// URL: /search.php?region=EU&city=Paris
$location = $_GET['city'];
echo $location;
?>Соберите безопасную проверку параметра
Соберите PHP-скрипт, который проверяет, был ли передан параметр 'user' в GET-запросе. Если да, он выводит приветствие. Используйте только необходимые части и разместите их в правильном порядке.
<?php echo "Привет, " . $_GET['user'];}if (isset($_GET['user'])) {echo $_POST['user'];if (empty($_GET['user'])) {Сопоставьте термины и их описания
Сопоставьте термины, связанные с GET-запросами, с их правильными определениями. Перетащите элементы из правого столбца так, чтобы они соответствовали терминам в левом.
Защитите вывод от XSS-атаки
Приведенный код уязвим для межсайтового скриптинга (XSS), так как он выводит данные от пользователя без обработки. Исправьте строку с `echo`, чтобы сделать вывод безопасным.
<?php// URL: index.php?comment=<script>alert('XSS')</script>if (isset($_GET['comment'])) { echo "Ваш комментарий: " . $_GET['comment'];}?>Предскажите результат с оператором `??`
В коде используется оператор нулевого слияния (`??`) для установки значения по умолчанию. Определите, что выведет скрипт, если URL не содержит параметра 'user', и впишите результат в поле.
<?php
// URL: /home.php
$username = $_GET['user'] ?? 'Guest';
echo $username;
?>Соберите обработчик пагинации из банка
Заполните пропуски в коде, чтобы создать корректный обработчик номера страницы. Скрипт должен брать номер страницы из GET-параметра 'page', приводить его к целому числу и устанавливать значение по умолчанию `1`, если параметр отсутствует. Перетащите токены из банка в нужные места.
<?php
// URL: /products.php?page=3
$page = isset(input1S['page']) ? (int)input2S['page'] : 1;
echo "Вы на странице номер: " . input3S;
?>Восстановите порядок обработчика формы поиска
Расставьте строки кода в правильной последовательности. Скрипт должен принимать поисковый запрос (`query`) и категорию (`category`) из GET-параметров, устанавливать для категории значение по умолчанию 'all' и выводить безопасное сообщение о поиске.
if (!empty($_GET['query'])) {<?php}?> echo "Поиск '" . htmlspecialchars($_GET['query']) . "' в категории '" . $category . "'";$category = $_GET['category'] ?? 'all';