get_cfg_var() 更轻量,直接返回 php.ini 原始配置值(如 "1" 或 ""),不支持运行时修改值,且可能被禁用;ini_get_all() 返回结构化配置数组,含 global_value 和 local_value;get_loaded_extensions() 和 get_extension_funcs() 用于验证扩展及函数存在性;phpversion() 和 PHP_VERSION_ID 用于版本判断。
get_cfg_var() 查特定 PHP 配置项比 phpinfo() 更轻量,适合只查某一项(比如 upload_max_filesize 或 memory_limit)。它直接返回配置值,不输出 HTML,可用于日志或 API 响应。
get_cfg_var('display_errors') 返回字符串 "1" 或 "",注意不是布尔值disable_functions 中含它),需先检查 function_exists('get_cfg_var')
ini_set() 修改过的值 —— 它只读取 php.ini 原始配置ini_get_all() 获取全部可读 ini 配置返回关联数组,键为配置名,值为包含 global_value(php.ini 值)、local_value(当前作用域值,如 .htaccess 或 ini_set 设置)的子数组。比 phpinfo() 结构化,适合调试配置覆盖问题。
print_r(ini_get_all('date')); // 只查 date.* 相关配置
// 输出类似:
// Array (
// [date.timezone] => Array ( [global_value] => UTC [local_value] => Asia/Shanghai ... )
// )ini_get_all('') 会返回所有配置,但可能包含敏感项(如 mysql.default_password),生产环境慎用access 字段标明是否可被 ini_set() 修改(如 7 表示可修改)opcache.enable 在 OPcache 启用后才可见)get_extension_funcs() 和 get_loaded_extensions() 查扩展能力当需要确认某个函数是否存在、或某扩展是否真被加载(而非仅出现在 php -m 列表里),这两个函数比翻 phpinfo() 页面更直接。
if (in_array('curl', get_loaded_extensions())) {
$curl_funcs = get_extension_funcs('curl');
echo "cURL 支持 " . count($curl_funcs) . " 个函数\n";
}get_loaded_extensions(true) 返回带版本号的扩展列表(PHP ≥ 8.0
get_extension_funcs('json') 在 JSON 扩展被禁用时返回 false,不是空数组zlib)可能提供函数但不显式列在 get_loaded_extensions() 中(取决于编译方式),此时可用 function_exists('gzopen') 逐个验证phpversion() 和 zend_version() 快速确认核心版本简单场景下,不需要完整信息页,只要知道版本号做兼容判断:phpversion() 返回 PHP 版本字符串(如 "8.2.12"),zend_version() 返回 Zend 引擎版本(如 "4.2.12"),二者常有微小差异。
phpversion('openssl') 可查扩展版本(若该扩展支持),但很多扩展不支持此用法,会返回 false
version_compare(phpversion(), '8.0', '>='),而非解析字符串PHP_VERSION_ID 是整数常量(如 80212),计算和比较更快,但不可用于运行时动态判断旧版本 PHP实际调试时,phpinfo() 的不可替代性在于它把配置、环境变量、HTTP 头、扩展初始化信息全堆在一起,而上述函数各自只管一块。真正要替代它,往往得组合调用 —— 比如先用 get_loaded_extensions() 确认扩展存在,再用 ini_get_all() 查其配置,最后用 function_exists() 验证关键函数可用。漏掉任一环,都可能误判环境状态。