贝利信息

CLI模式如何调phpinfo_命令行调用phpinfo输出格式【模式】

日期:2026-01-16 00:00 / 作者:看不見的法師
php -r "echo phpinfo();" 只输出部分信息,因 CLI 模式默认调用 phpinfo(INFO_MODULES)(值为8),而非 INFO_ALL(-1);需显式传参如 phpinfo(-1) 或 phpinfo('INFO_ALL') 才显示完整配置。

php -r "echo phpinfo();" 为什么只输出部分信息

命令行调用 phpinfo() 默认只显示“模块信息”和“PHP 配置摘要”,不输出完整的 HTML 表格结构——因为 CLI SAPI 内部会自动将 phpinfo() 的输出模式设为 INFO_MODULES(即常量值 8),而非 Web 模式下的 INFO_ALL(值为 -1)。

这不是 bug,是 PHP CLI 模式的设计行为:避免大量 HTML 标签污染终端、提升可读性。但如果你需要完整配置项(比如查看 opcache.enable 是否生效、extension_dir 路径、或所有已加载的 ini 文件),就得显式传参。

INFO_* 常量在 CLI 中必须显式写数字或全大写常量名

CLI 模式下 php -r 不自动加载预定义常量别名(如 INFO_ALL),直接写常量名会报 PHP Notice: Use of undefined constant INFO_ALL。必须用以下任一方式:

推荐用数值,简洁且无版本依赖。常见值参考:

INFO_GENERAL     → 1
INFO_CREDITS     → 2
INFO_CONFIGURATION → 4
INFO_MODULES     → 8
INFO_ENVIRONMENT → 16
INFO_VARIABLES   → 32
INFO_LICENSE     → 64
INFO_ALL         → -1

想导出为文本/JSON/HTML 便于搜索或存档?别直接重定向

直接 php -r "phpinfo(INFO_ALL);" > info.txt 会导致换行错乱、ANSI 控制符残留(尤其在 macOS/Linux 终端),且无法过滤敏感字段(如 $_SERVER 中的 PATH、PWD)。

php -i 和 php -r "phpinfo()" 的实际差异

php -i 是 PHP 内置命令,等价于 php -r "phpinfo(INFO_ALL);",但它绕过用户代码执行环境,不受 disable_functions 影响(只要 CLI SAPI 本身没被禁用)。而 php -r 方式受当前 PHP 配置限制。

调试时优先用 php -i 快速确认基础环境;需要定制输出范围(比如只看扩展是否加载)才用 php -r + 显式参数。