PHPJuniorTechnical
Что такое суперглобальные переменные (superglobals) в PHP? Назовите наиболее распространённые.
Суперглобальные переменные PHP автоматически доступны в любой области видимости без объявления global. Основные: $_GET, $_POST, $_SERVER, $_SESSION, $_COOKIE, $_FILES, $_ENV, $_REQUEST, $GLOBALS.
Что такое суперглобальные переменные
Суперглобалы — предопределённые массивы PHP, доступные везде: в функциях, методах, замыканиях — без ключевого слова global. PHP заполняет их автоматически при обработке каждого запроса.
Основные суперглобалы
$_GET и $_POST
<?php
// URL: /search?q=php&page=2
$query = $_GET['q'] ?? ''; // 'php'
$page = (int)($_GET['page'] ?? 1); // 2
// POST-запрос с формы или JSON
$email = $_POST['email'] ?? '';
$password = $_POST['password'] ?? '';
$_SERVER
<?php
echo $_SERVER['REQUEST_METHOD']; // 'GET', 'POST', 'PUT'...
echo $_SERVER['REQUEST_URI']; // '/api/users?page=1'
echo $_SERVER['HTTP_HOST']; // 'example.com'
echo $_SERVER['REMOTE_ADDR']; // IP клиента (осторожно: может быть прокси)
echo $_SERVER['HTTP_USER_AGENT']; // строка браузера
echo $_SERVER['SCRIPT_FILENAME']; // абсолютный путь к скрипту
// Реальный IP через прокси (если доверяете заголовкам)
$ip = $_SERVER['HTTP_X_FORWARDED_FOR']
?? $_SERVER['HTTP_X_REAL_IP']
?? $_SERVER['REMOTE_ADDR'];
$_SESSION и $_COOKIE
<?php
session_start();
$_SESSION['user_id'] = 42;
// Cookie устанавливается через setcookie(), читается через $_COOKIE
$theme = $_COOKIE['theme'] ?? 'light';
$_FILES
<?php
// <input type="file" name="avatar">
if ($_FILES['avatar']['error'] === UPLOAD_ERR_OK) {
$tmpPath = $_FILES['avatar']['tmp_name'];
$origName = basename($_FILES['avatar']['name']);
$size = $_FILES['avatar']['size']; // байты
$mime = $_FILES['avatar']['type']; // НЕ доверять: проверяем сами
// Проверка реального MIME
$finfo = new finfo(FILEINFO_MIME_TYPE);
$realMime = $finfo->file($tmpPath);
if (!in_array($realMime, ['image/jpeg', 'image/png', 'image/webp'])) {
throw new RuntimeException('Invalid file type');
}
$dest = '/var/uploads/' . bin2hex(random_bytes(8)) . '.jpg';
move_uploaded_file($tmpPath, $dest);
}
$_ENV и $GLOBALS
<?php
// $_ENV — переменные окружения (если variables_order содержит 'E')
$dbUrl = $_ENV['DATABASE_URL'] ?? getenv('DATABASE_URL');
// $GLOBALS — все переменные глобальной области видимости
$GLOBALS['config'] = ['debug' => false];
// Внутри функции:
function test(): void {
echo $GLOBALS['config']['debug'] ? 'debug' : 'prod';
}
Подводные камни
- Доверять
$_FILES['file']['type']: браузер передаёт MIME-тип как строку, которую легко подделать. Всегда проверяйте черезfinfo. - Использовать данные из
$_GET/$_POSTбез валидации и экранирования: прямой путь к XSS и SQL-инъекциям. - Доверять
$_SERVER['REMOTE_ADDR']в качестве источника истины: за reverse-proxy это будет IP прокси, аHTTP_X_FORWARDED_FORподделывается клиентом. - Читать переменные окружения только через
$_ENV: еслиvariables_orderв php.ini не содержитE, массив пустой — используйтеgetenv(). - Использовать
$_REQUEST: он объединяет GET, POST и COOKIE в один массив, что затрудняет понимание источника данных и порядок приоритетов. - Изменять
$GLOBALSкак глобальное состояние: тяжело тестировать и дебажить, предпочитайте dependency injection. - Хранить чувствительные данные в
$_COOKIEбез шифрования: cookie доступны на клиенте и могут быть изменены пользователем.
Common mistakes
- Сводить superglobals к названию метода без lifecycle и failure path.
- Игнорировать модель runtime: интерпретируемый runtime PHP 8.x, обычно запускаемый как отдельный запрос в FPM, CLI или worker-процессе.
- Не отделять validation, authorization, transaction boundary и business logic.
What the interviewer is testing
- Объясняет superglobals через конкретную точку lifecycle в PHP.
- Приводит корректный минимальный пример без вымышленных методов или callbacks.
- Называет edge cases: пустые значения, ошибки, транзакции, безопасность или concurrency.