PHP.mk документација

dl

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

function.dl.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека function.dl.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
dl

Референца за `function.dl.php` со подобрена типографија и навигација.

function.dl.php

dl

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

dlВчитува PHP екстензија во тек на извршување

= NULL

dl(string $extension_filename): bool

Вчитува PHP екстензија дадена со параметарот extension_filename.

од PHP 8.0.0. Силно се обесхрабрува потпирањето на оваа функција. extension_loaded() за тестирање дали дадена екстензија е веќе достапна или не. Ова работи и на вградени екстензии и на динамички вчитани (или преку php.ini or dl()).

Ги ескејпува специјалните знаци во стринг за употреба во SQL изјава

и вгради CLI и SAPIкога се извршува од командна линија. CGI SAPI Овој параметар е

Параметри

extension_filename

името на датотеката на екстензијата за вчитување, што исто така зависи од вашата платформа. На пример, only екстензија (ако е компајлирана како споделен модул, не по дифолт!) ќе се вика sockets на Unix платформите додека се вика sockets.so на Windows платформата. php_sockets.dll Директориумот од каде што се вчитува екстензијата зависи од вашата платформа:

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 or /usr/local/php/lib/php/extensions/no-debug-zts-20010901.

Вратени вредности

Патеката до PHP скриптата што треба да се провери. true на успех или false при неуспех. Ако функционалноста за вчитување модули не е достапна или е оневозможена (со поставување enable_dl исклучено во php.ini) еден E_ERROR се емитува и извршувањето се прекинува. Ако dl() не успее бидејќи наведената библиотека не можеше да се вчита, покрај false an E_WARNING порака се емитува.

Примери

Пример #1 dl() examples

<?php
// Example loading an extension based on OS
if (!extension_loaded('sqlite')) {
if (
strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
dl('php_sqlite.dll');
} else {
dl('sqlite.so');
}
}

// Or using PHP_SHLIB_SUFFIX constant
if (!extension_loaded('sqlite')) {
$prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '';
dl($prefix . 'sqlite.' . PHP_SHLIB_SUFFIX);
}
?>

Белешки

Забелешка:

dl() е чувствително на големи и мали букви на Unix платформи.

Види Исто така

Белешки од корисници 2 забелешки

shaunspiller на spammenot-gmail точка com
пред 17 години
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');

?>
mag_2000 на front точка ru
20 години пред
<?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()

?>
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.