0

0

如何分段加载phpinfo_减少phpinfo一次性输出负担【分段】

雪夜

雪夜

发布时间:2026-01-17 16:55:13

|

353人浏览过

|

来源于php中文网

原创

分段查看phpinfo需服务端按需生成:用flag参数(如INFO_CONFIGURATION)可原生切片;需分页时用ini_get_all()等函数手动构造;生产环境必须鉴权且禁用完整输出。

如何分段加载phpinfo_减少phpinfo一次性输出负担【分段】

直接调用 phpinfo() 会一次性输出全部 PHP 配置、扩展、环境信息,页面体积大(常超 500KB)、渲染慢、甚至触发 Nginx/Apache 的响应体截断或超时。**不能靠前端分页或 CSS 隐藏来“假装”分段——PHP 进程仍需生成并输出全部内容。真正的分段必须在服务端按需生成子集。**

phpinfo() 的第二个参数做模块级切片

phpinfo() 支持传入一个整数 flag,指定只输出某类信息,避免全量渲染。这是最轻量、原生、无需额外依赖的分段方式。

  • phpinfo(INFO_GENERAL):PHP 版本、系统、构建信息等基础头
  • phpinfo(INFO_CONFIGURATION)php.ini 路径和所有 Directive 值(最常查的部分)
  • phpinfo(INFO_MODULES):已加载的扩展列表(不含详细配置)
  • phpinfo(INFO_ENVIRONMENT)$_ENV 和服务器环境变量
  • phpinfo(INFO_VARIABLES)$_GET/$_POST/$_SERVER 等超全局变量(注意敏感信息!)

例如,单独查看配置项只需:

 

ini_get_all() + get_loaded_extensions() 手动构造可分页片段

当需要更细粒度控制(比如每页 20 个 ini 项、或按扩展名分组),phpinfo() 的 flag 就不够用了。此时应绕过 phpinfo(),改用底层函数采集数据再格式化。

立即学习PHP免费学习笔记(深入)”;

Text-To-Song
Text-To-Song

免费的实时语音转换器和调制器

下载
  • ini_get_all(null, false) 返回所有 ini 配置的关联数组,可 array_chunk() 分页
  • get_loaded_extensions() 获取扩展名列表,再对每个扩展调用 extension_loaded($ext)ini_get_all($ext) 获取其专属配置
  • 避免调用 phpinfo(INFO_MODULES) 后再解析 HTML —— 不稳定且开销大

示例:分页输出前 10 个 ini 项

 INI items (page {$page})";
foreach ($chunk as $key => $val) {
    echo "
{$key} = {$val['local_value']} ({$val['global_value']})
"; } ?>

禁止在生产环境暴露完整 phpinfo() 页面

哪怕做了分段,只要 URL 可访问、无鉴权,就等于把服务器底裤交给任何人看。常见高危后果:

  • INFO_VARIABLES 泄露数据库密码、API Key(若通过 $_SERVER 注入)
  • INFO_ENVIRONMENT 暴露 HOMEPATH、容器 ID 等部署细节
  • 攻击者用 INFO_CONFIGURATION 确认 disable_functions 是否绕过成功

必须做到:

  • 分段脚本文件名不叫 phpinfo.php,且不在 Web 根目录下直连(如放 /var/www/internal/tools/ 并用 Nginx location 限制 IP)
  • 每个脚本开头强制校验登录态或 Token:if (!isset($_SESSION['admin']) || $_SESSION['admin'] !== true) die('Access denied');
  • 上线前删除所有调试用的 phpinfo() 文件——临时需求用完即删

分段的本质不是让页面“看起来快”,而是让 PHP 进程少做无用功。flag 切片最快,手动采集最灵活,但无论哪种,漏掉权限控制就等于白做。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2600

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1625

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1510

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号