PHP 8.5.0 Alpha 2 available for testing

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-платформах, в той час як на Windows-платформах воно буде називатись php_sockets.dll.

Директорія, звідки розширення завантажується, залежить від платформи:

Windows - Якщо явно не підключено у файлі php.ini, початково, розширення завантажується із C:\php5.

Unix - Якщо явно не підключено у файлі php.ini, початково, директорія розширення залежить від

  • чи було зібрано PHP з параметром --enable-debug, чи ні
  • чи було зібрано PHP з підтримкою ZTS (Zend Thread Safety), чи ні
  • поточний внутрішній номер ZEND_MODULE_API_NO (внутрішній номер API Zend-модуля, який, як правило, є датою major-зміни модуля 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-платформах.

Прогляньте також

add a note

User Contributed Notes 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:

<?php

function 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 support
load_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
<?php

function 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