dl() - php 选项信息函数
dl()
(PHP 4, PHP 5, PHP 7)
运行时载入一个 PHP 扩展
说明
dl(string $library): bool载入指定参数$library的 PHP 扩展。
使用extension_loaded()来测试指定的扩展是否已经激活。这既能用于内建的扩展也可以用于动态加载的扩展(既可以通过php.ini也可以通过dl())。
Warning在 PHP 5.3 里,此函数被某些 SAPI 移除了。
参数
$library此参数仅仅是要加载的扩展的文件名,依赖于你的平台。比如,sockets(作为共享模块编译,而不是默认的!)在 Unix 平台上称为sockets.so而在 Windows 平台上是php_sockets.dll。
扩展加载的目录依赖于你的平台:
Windows -如果没有在php.ini里明确设置,扩展默认会从C:php5加载。
Unix -如果没有在php.ini里明确设置,默认的扩展目录依赖于
- PHP 是否通过--enable-debug选项构建
- PHP 是否以(实验性质的)ZTS (Zned 线程安全)支持构建
- 当前的内部ZEND_MODULE_API_NO(Zend 内部模块 API 数字,基本上是主要模块修改时的日期)
返回值
成功时返回TRUE
,或者在失败时返回FALSE
。如果加载模块的功能是无效或者禁用的(既可以通过设置关闭enable_dl设置,也可以通过启用php.ini里的安全模式)将导致一个E_ERROR
并中断执行。如果因为指定的库无法加载而导致dl()失败,除了返回FALSE
,还会产生一个E_WARNING
的消息。
范例
Example #1dl()例子
更新日志
版本 | 说明 |
---|---|
7.0.0 | PHP-FPM 模式下已禁用dl()。 |
5.3.9 | 尽管不推荐,但 PHP-FPM 模式下启用了dl()。 |
5.3.0 | 由于稳定性,dl()在某些 SAPI 中被禁用。仅仅允许dl()的 SAPI 为 CLI 和 Embed。使用扩展加载指令作为替代。 |
注释
Note:当 PHP 以支持 ZTS 构建时,不支持dl()。使用扩展加载指令作为替代。Note:
在某些 Unix 平台上,dl()是大小写敏感的。
Note:当 PHP 运行在安全模式时,不能使用此函数。
参见
- 扩展加载指令
extension_loaded()
检查一个扩展是否已经加载
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: Examples:
It would be nice to know which SAPIs removed the function. Telling me 'This function has been removed from some SAPIs in PHP 5.3.' is pretty much useless and I feel mocked. Or do the writers of the documentation don't know from which SAPIs it has been removed?
Like with eval(), the only correct way to use dl() is to not use it. Test if a function(s) you intend to use are available. If not, complain to the user or implement a workaround. Not to mention dl() issues in a multithreading environment.
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!