(PHP 4, PHP 5, PHP 7)
dl — Carga una extensión de PHP durante la ejecución
$library
) : bool
Carga la extensión PHP dada por el parámetro
library
.
Utilice la función extension_loaded() para comprobar si la extensión ya está cargada o no. Funciona tanto para extensiones ya integradas en PHP o para extensiones que se han cargado dinámicamente (ya sea a través de php.ini o dl()).
Esta función ha sido eliminada de la mayoría de las SAPI en PHP 5.3.0, y de PHP-FPM en PHP 7.0.0.
library
Este parámetro es solamente el fichero de la extensión a cargar el cual depende del sistema operativo. Por ejemplo, la extensión sockets (si se compila como librería, no como parte de PHP) Se llamará sockets.so en sistemas Unix mientras que en Windows se llamará php_sockets.dll.
El directorio desde donde la extensión será cargada también depende del sistema operativo:
En Windows - a no ser que se defina explicitamente en php.ini, la extensión será cargada por defecto desde C:\php4\extensions\ (PHP4) o C:\php5\ en (PHP 5).
Unix - a no ser que se defina en php.ini, el directorio de extensiones por defecto depende de
Devuelve TRUE
en caso de éxito o FALSE
en caso de error. Si la funcionalidad de cargar módulos no está disponible
o ha sido deshabilitada (ya sea activando
enable_dl off o habilitando el modo seguro
en php.ini) Se producirá un E_ERROR
y se parará la ejecucción de PHP. Si dl() falló porque la
librería especificacda no pudo cargarse a demás de FALSE
se
producirá un mensaje E_WARNING
.
Ejemplo #1 Ejemplos de dl()
<?php
// En este ejemplo se carga una extensión u otra dependiendo del sistema operativo
if (!extension_loaded('sqlite')) {
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
dl('php_sqlite.dll');
} else {
dl('sqlite.so');
}
}
// O si la constante PHP_SHLIB_SUFFIX está disponible desde PHP 4.3.0
if (!extension_loaded('sqlite')) {
$prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '';
dl($prefix . 'sqlite.' . PHP_SHLIB_SUFFIX);
}
?>
Versión | Descripción |
---|---|
7.0.0 | dl() está deshabilitado en PHP-FPM. |
5.3.9 | dl() está deshabilitado en PHP-FPM, aunque se desaconseja. |
5.3.0 | dl() está desactivado en algunos módulos SAPI por problemas de estabilidad. Los únicos modulos SAPI que permiten dl() son: CLI, CGI and Embed. En su lugar usar las directivas Directivas de carga de extensiones |
Nota:
dl() no se soporta cuando PHP es compilado con soporte ZTS. Use en su lugar Directivas de carga de extensiones instead.
Nota:
dl() es sensible a mayúsculas en sistemas Unix.
Nota: Esta función está deshabilitada cuando PHP se ejecuta en modo seguro.