parse_url
(PHP 4, PHP 5, PHP 7)
parse_url — Разбирает URL и возвращает его компоненты
Описание
Эта функция разбирает URL и возвращает ассоциативный массив, содержащий все компоненты URL, которые в нём присутствуют. Элементы массива не будут декодированы как URL.
Эта функция не предназначена для проверки на корректность данного URL, она только разбивает его на нижеперечисленные части. Частичные URL также принимаются, parse_url() пытается сделать всё возможное, чтобы разобрать их корректно.
Список параметров
-
url
-
URL для разбора. Недопустимые символы будут заменены на знаки подчёркивания
_
.
-
component
-
Укажите одну из констант
PHP_URL_SCHEME
,PHP_URL_HOST
,PHP_URL_PORT
,PHP_URL_USER
,PHP_URL_PASS
,PHP_URL_PATH
,PHP_URL_QUERY
илиPHP_URL_FRAGMENT
, чтобы получить только конкретный компонент URL в виде строки (string). Исключением является указаниеPHP_URL_PORT
, в этом случае возвращаемое значение будет типа int.
Возвращаемые значения
При разборе значительно некорректных URL-адресов parse_url() может вернуть false
.
Если параметр component
будет опущен, функция возвратит
ассоциативный массив (array). В массиве будет находиться по крайней мере один элемент.
Возможные ключи в этом массиве:
- scheme - например, http
- host
- port
- user
- pass
- path
-
query - после знака вопроса
?
-
fragment - после знака решётки
#
Если параметр component
определён,
функция parse_url() вернёт строку (string)
(или число (int), в случае PHP_URL_PORT
)
вместо массива (array).
Если запрошенный компонент не существует в данном URL, будет возвращён null
.
Примеры
Пример #1 Пример использования parse_url()
<?php
$url = 'http://username:password@hostname:9090/path?arg=value#anchor';
var_dump(parse_url($url));
var_dump(parse_url($url, PHP_URL_SCHEME));
var_dump(parse_url($url, PHP_URL_USER));
var_dump(parse_url($url, PHP_URL_PASS));
var_dump(parse_url($url, PHP_URL_HOST));
var_dump(parse_url($url, PHP_URL_PORT));
var_dump(parse_url($url, PHP_URL_PATH));
var_dump(parse_url($url, PHP_URL_QUERY));
var_dump(parse_url($url, PHP_URL_FRAGMENT));
?>
Результат выполнения данного примера:
array(8) { ["scheme"]=> string(4) "http" ["host"]=> string(8) "hostname" ["port"]=> int(9090) ["user"]=> string(8) "username" ["pass"]=> string(8) "password" ["path"]=> string(5) "/path" ["query"]=> string(9) "arg=value" ["fragment"]=> string(6) "anchor" } string(4) "http" string(8) "username" string(8) "password" string(8) "hostname" int(9090) string(5) "/path" string(9) "arg=value" string(6) "anchor"
Пример #2 Пример использования parse_url() при отсутствии протокола
<?php
$url = '//www.example.com/path?googleguy=googley';
// До 5.4.7 в path выводилось "//www.example.com/path"
var_dump(parse_url($url));
?>
Результат выполнения данного примера:
array(3) { ["host"]=> string(15) "www.example.com" ["path"]=> string(5) "/path" ["query"]=> string(17) "googleguy=googley" }
Примечания
Замечание:
Эта функция может выдать некорректный результат для относительных URL.
Замечание:
Эта функция предназначена специально для разбора URL-адресов, а не URI. Однако, чтобы соответствовать требованиям обратной совместимости PHP, она делает исключение для протокола file://, в которой допускаются тройные слеши (file:///...). Для любого другого протокола это недопустимо.
Смотрите также
- pathinfo() - Возвращает информацию о пути к файлу
- parse_str() - Разбирает строку в переменные
- http_build_query() - Генерирует URL-кодированную строку запроса
- dirname() - Возвращает имя родительского каталога из указанного пути
- basename() - Возвращает последний компонент имени из указанного пути
- » RFC 3986