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

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 是否生效、exten

sion_dir 路径、或所有已加载的 ini 文件),就得显式传参。

  • php -r "phpinfo();" → 等价于 phpinfo(INFO_MODULES),只显示模块列表
  • php -r "phpinfo(INFO_ALL);" → 输出全部,含编译选项、环境变量、HTTP 头(为空)、配置文件路径等
  • php -r "phpinfo(INFO_CONFIGURATION);" → 仅显示 .ini 加载情况和配置项(最常用排查场景)

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

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

  • 用整数值:例如 php -r "phpinfo(-1);"-1 = INFO_ALL
  • 用全大写字符串形式的常量名(PHP 7.4+ 支持):php -r "phpinfo('INFO_ALL');"
  • 先定义常量再调用(兼容旧版):php -r "define('INFO_ALL', -1); phpinfo(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 -r "ob_start(); phpinfo(INFO_ALL); echo strip_tags(ob_get_clean());" > info.txt
  • 提取关键路径(如配置文件位置):php --iniphp -r "echo 'Loaded config: ' . get_cfg_var('cfg_file_path') ?: 'none';"
  • 生成 JSON(需额外处理):CLI 模式无原生 JSON 输出,可用 php -i(等价于 phpinfo(INFO_ALL))配合 grepawk 提取,例如:php -i | grep "extension_dir\|memory_limit\|upload_max_filesize"

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

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

  • 如果 phpinfodisable_functions 列表中,php -r "phpinfo();" 会报 Warning: phpinfo() has been disabled;但 php -i 仍可运行
  • php -i 输出默认带 ANSI 颜色(可加 --no-color 关闭),php -r 不带
  • php -i 不能指定子集(如只查模块),始终输出全部

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