array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ru', ), 'this' => array ( 0 => 'function.dl.php', 1 => 'dl', ), 'up' => array ( 0 => 'ref.info.php', 1 => 'Опции PHP/информационные функции', ), 'prev' => array ( 0 => 'function.cli-set-process-title.php', 1 => 'cli_set_process_title', ), 'next' => array ( 0 => 'function.extension-loaded.php', 1 => 'extension_loaded', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ru', 'path' => 'reference/info/functions/dl.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4, PHP 5, PHP 7, PHP 8)
dl — Загружает модуль PHP во время выполнения
Загружает модуль PHP, заданный аргументом extension_filename
.
Чтобы проверить, что заданный модуль уже загружен, используйте функцию extension_loaded(). Функция работает как для встроенных модулей, так и для динамически загруженных (т.е. загруженных как через php.ini, так и через dl()).
Функция доступна только для CLI и встроенного SAPI, а также для CGI SAPI при запуске из командной строки.
extension_filename
Аргумент содержит только имя файла модуля, который требуется загрузить. Это имя зависит от платформы. Например, модуль sockets (если скомпилирован, как загружаемый модуль, а не модуль по умолчанию!) будет называться sockets.so на Unix-платформах, и php_sockets.dll в среде Windows.
Директория, из которой модуль должен быть загружен, также зависит от платформы:
Windows - Если явно не задано в php.ini, модуль будет грузиться из C:\php5\ по умолчанию.
Unix - Если явно не задано в php.ini, директория по умолчанию зависит от
--enable-debug
или без неё
ZEND_MODULE_API_NO
(номер внутреннего модуля Zend API, который, как правило, является датой
основного изменения API модуля, например 20010901
)
<install-dir>/lib/php/extensions/ <debug-or-not>-<zts-or-not>-ZEND_MODULE_API_NO
,
например,
/usr/local/php/lib/php/extensions/debug-non-zts-20010901
или
/usr/local/php/lib/php/extensions/no-debug-zts-20010901.
Возвращает true
в случае успешного выполнения или false
, если возникла ошибка. Если механизм загрузки модулей недоступен или отключён
(значение off настройки enable_dl в php.ini), будет выдана ошибка
E_ERROR
и выполнение прекращается. Если
dl() не сможет загрузить заданную библиотеку, то в дополнение
к false
будет выдано сообщение E_WARNING
.
Пример #1 Примеры использования dl()
<?php
// Пример загрузки модуля, основываясь на ОС
if (!extension_loaded('sqlite')) {
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
dl('php_sqlite.dll');
} else {
dl('sqlite.so');
}
}
// Или на константе PHP_SHLIB_SUFFIX
if (!extension_loaded('sqlite')) {
$prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '';
dl($prefix . 'sqlite.' . PHP_SHLIB_SUFFIX);
}
?>
Замечание:
dl() чувствительна к регистру на Unix-платформах.