Этот модуль посвящен валидации и обработке текстовых данных из форм в PHP. Вы научитесь проверять заполненность полей, очищать строки от лишних пробелов и вредоносного кода, проверять длину текста и соответствие формату (например, email).
В заданиях вам предстоит работать с функциями empty(), trim(), htmlspecialchars(), а также с регулярными выражениями и фильтрами.
Мы начнем с простых проверок и закончим построением комплексной логики валидации. Будьте внимательны к синтаксису и логическому порядку действий. Удачи!
- Модуль 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. Проверка заполненности поля
Необходимо проверить, что поле имени пользователя **не** является пустым. Заполните пропуск правильной функцией и оператором отрицания.
$username = $_POST['user'];
// Если имя НЕ пустое, сохраняем его
if (input1S(input2S($username))) {
saveUser($username);
} else {
echo "Введите имя!";
}2. Очистка пробелов
Пользователь часто случайно ставит пробелы в начале или конце ввода. Определите, что выведет код после обработки строки функцией `trim`.
$input = " PHP Rulez ";
$clean = trim($input);
echo "Script: " . $clean . "!";3. Длина строки после валидации
Частая задача: проверить длину пароля, предварительно убрав случайные пробелы. Напишите число, которое выведет этот код.
$password = " 123456 ";
$real_password = trim($password);
echo strlen($real_password);4. Очистка vs Проверка
Распределите функции PHP на две группы: те, что изменяют данные (Санитизация/Очистка), и те, что просто проверяют состояние или формат (Валидация).
5. Алгоритм проверки комментария
Соберите код обработки комментария в правильном порядке: получение данных -> очистка от HTML тегов -> проверка длины -> сохранение или ошибка.
$comment = $_POST['text'];$safe_comment = htmlspecialchars($comment);if (strlen($safe_comment) > 10) { saveComment($safe_comment);} else { echo "Комментарий слишком короткий";}$comment = htmlspecialchars($_POST['text']]);if (strlen($comment) > 10) {6. Валидация Email
Используйте встроенную функцию фильтрации для проверки корректности Email. Заполните пропуски.
$email = "user@example.com";
// Проверяем формат
if (input1S($email, input2S) === input3S) {
echo "Некорректный Email";
} else {
echo "Email принят";
}7. Ошибки в проверке возраста
Найдите и исправьте две ошибки в коде. Первая — синтаксическая (пропущен символ), вторая — логическая (неверный оператор сравнения для проверки совершеннолетия). Условие: доступ только с 18 лет включительно.
<?php$age = 17;if ($age > 18) { echo "Доступ разрешен"} else { echo "Вам рано";}8. Проверка логина регулярным выражением
Необходимо разрешить логин, состоящий только из латинских букв и цифр. Допишите регулярное выражение и функцию проверки.
$login = "User2024";
// Функция возвращает 1, если шаблон совпал
if (input1S(input2S, $login)) {
echo "Логин корректен";
} else {
echo "Только буквы и цифры!";
}9. Фильтры PHP и их назначение
Сопоставьте константы фильтров с их действием. Обратите внимание на разницу между VALIDATE (проверка) и SANITIZE (очистка).
FILTER_SANITIZE_SPECIAL_CHARSFILTER_VALIDATE_INTFILTER_SANITIZE_NUMBER_INTFILTER_VALIDATE_EMAIL