PHP Conference Fukuoka 2025

dl

(PHP 4, PHP 5, PHP 7, PHP 8)

dlЗагружает модуль PHP во время выполнения

Описание

dl(string $extension_filename): bool

Загружает модуль 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, директория по умолчанию зависит от

  • PHP собран с настройкой --enable-debug или без неё
  • PHP собран с поддержкой ZTS (Zend Thread Safety) или нет
  • текущий внутренний номер 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-платформах.

Смотрите также

Добавить

Примечания пользователей 2 notes

up
15
shaunspiller at spammenot-gmail dot com
16 years ago
dl is awkward because the filename format is OS-dependent and because it can complain if the extension is already loaded. This wrapper function fixes that:<?phpfunction load_lib($n, $f = null) {    return extension_loaded($n) or dl(((PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '') . ($f ? $f : $n) . '.' . PHP_SHLIB_SUFFIX);}?>Examples:<?php// ensure we have SSL and MySQL supportload_lib('openssl');load_lib('mysql');// a rare few extensions have a different filename to their extension name, such as the image (gd) library, so we specify them like this:load_lib('gd', 'gd2');?>
up
-2
mag_2000 at front dot ru
19 years ago
<?phpfunction dl_local( $extensionFile ) {   //make sure that we are ABLE to load libraries   if( !(bool)ini_get( "enable_dl" ) || (bool)ini_get( "safe_mode" ) ) {     die( "dh_local(): Loading extensions is not permitted.\n" );   }     //check to make sure the file exists   if( !file_exists( $extensionFile ) ) {     die( "dl_local(): File '$extensionFile' does not exist.\n" );   }      //check the file permissions   if( !is_executable( $extensionFile ) ) {     die( "dl_local(): File '$extensionFile' is not executable.\n" );   } //we figure out the path $currentDir = getcwd() . "/"; $currentExtPath = ini_get( "extension_dir" ); $subDirs = preg_match_all( "/\//" , $currentExtPath , $matches ); unset( $matches );      //lets make sure we extracted a valid extension path   if( !(bool)$subDirs ) {     die( "dl_local(): Could not determine a valid extension path [extension_dir].\n" );   }  $extPathLastChar = strlen( $currentExtPath ) - 1;    if( $extPathLastChar == strrpos( $currentExtPath , "/" ) ) {     $subDirs--;   } $backDirStr = "";      for( $i = 1; $i <= $subDirs; $i++ ) {     $backDirStr .= "..";       if( $i != $subDirs ) {         $backDirStr .= "/";       }   } //construct the final path to load $finalExtPath = $backDirStr . $currentDir . $extensionFile;    //now we execute dl() to actually load the module     if( !dl( $finalExtPath ) ) {     die();   } //if the module was loaded correctly, we must bow grab the module name $loadedExtensions = get_loaded_extensions(); $thisExtName = $loadedExtensions[ sizeof( $loadedExtensions ) - 1 ];   //lastly, we return the extension name  return $thisExtName;}//end dl_local()?>
To Top