array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'pt_BR', ), 'this' => array ( 0 => 'function.dl.php', 1 => 'dl', ), 'up' => array ( 0 => 'ref.info.php', 1 => 'Funções para Opções/Info do 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' => 'pt_BR', '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 — Carrega uma extensão do PHP durante a execução
Carrega a extensão do PHP indicada pelo parâmetro
extension_filename
.
Use extension_loaded() para testar se uma extensão está disponível ou não. Isto funciona para extensões internas e para aquelas carregadas dinamicamente (através do php.ini ou da função dl()).
Esta função somente está disponível no modos CLI e SAPI internalizado, e na SAPI CGI quando rodado em linha de comando.
extension_filename
Este parâmetro é somente o nome do arquivo da extensão a carregar o qual também depende da sua plataforma. Por exemplo, a extensão sockets (se compilada como módulo compartilhado, não o padrão!) seria chamada sockets.so em plataformas Unix enquanto é chamada php_sockets.dll na plataforma Windows.
O diretório a partir do qual a extensão é carregada depende da sua plataforma:
Windows - Se não for explicitamente definido no php.ini, a extensão é carregada a partir de C:\php5\ por padrão.
Unix - Se não for explicitamente definido no php.ini, o diretório padrão das extensões depende de
--enable-debug
ou não
ZEND_MODULE_API_NO
(o número Zend
internal module API, o que é basicamente a data onde houve uma mudança maior na
API ex. 20010901
)
<install-dir>/lib/php/extensions/ <debug-or-not>-<zts-or-not>-ZEND_MODULE_API_NO
,
e.g.
/usr/local/php/lib/php/extensions/debug-non-zts-20010901
or
/usr/local/php/lib/php/extensions/no-debug-zts-20010901.
Retorna true
em caso de sucesso ou false
em caso de falha. Se a funcionalidade de carregar módulos não estiver disponível
ou foi desabilitada (por configurar
enable_dl como off
no php.ini) então um erro E_ERROR
é disparado
e a execução é interrompida. Se dl() falhar porque a
biblioteca especificada não puder ser carregada, além de retornar false
uma
mensagem E_WARNING
é emitida.
Exemplo #1 Exemplosdl()
<?php
// Exemplo de carregar umas extensção com base no sistema operacional
if (!extension_loaded('sqlite')) {
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
dl('php_sqlite.dll');
} else {
dl('sqlite.so');
}
}
// Or, the PHP_SHLIB_SUFFIX constant is available as of PHP 4.3.0
if (!extension_loaded('sqlite')) {
$prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '';
dl($prefix . 'sqlite.' . PHP_SHLIB_SUFFIX);
}
?>
Nota:
dl() diferencia maiúsculas e minúsculas em sistemas Unix.