0

0

phpinfo输出含HTTP头吗_用phpinfo查请求头信息法【核查】

看不見的法師

看不見的法師

发布时间:2026-01-18 18:56:02

|

549人浏览过

|

来源于php中文网

原创

phpinfo() 默认不输出 HTTP 请求头,因其仅显示 PHP 环境配置,与请求上下文无关;获取请求头应使用 $_SERVER 或 getallheaders()。

phpinfo输出含http头吗_用phpinfo查请求头信息法【核查】

phpinfo() 默认不输出 HTTP 请求头

phpinfo() 是 PHP 内置的调试函数,它只输出 PHP 运行环境的配置、扩展、常量、版本等信息,不会显示当前请求的 HTTP 头(如 User-AgentRefererAuthorization 等)。它的输出属于服务器端环境快照,和本次请求的上下文无关。

常见误解是:打开 phpinfo.php 页面后看到一堆表格,以为其中某个 section 包含了请求头 —— 实际上没有。即使你用 curl -H "X-Test: 123" http://localhost/phpinfo.php 发送自定义头,phpinfo() 的输出里也找不到 X-Test

想看请求头?得用 $_SERVER 或 getallheaders()

PHP 中获取请求头有两条主流路径:

  • $_SERVER 数组包含部分重写后的请求头,命名规则为 HTTP_XXX(大写、下划线分隔、- 转为 _),例如 HTTP_USER_AGENTHTTP_ACCEPT_LANGUAGE;但不是所有头都会出现,比如 CookieHostContent-Type 会以独立键存在(HTTP_COOKIEHTTP_HOSTCONTENT_TYPE
  • getallheaders() 函数(仅在 Apache 模块模式或 FastCGI 下可用)能返回原始请求头的关联数组,键名保持原始大小写(如 User-Agent),更接近真实请求;但在 Nginx + PHP-FPM 组合中默认不可用,需额外配置或改用 apache_request_headers()(仅限 Apache)

简单验证方式:

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

Lyrics Generator
Lyrics Generator

免费人工智能歌词生成器和人工智能歌曲作家

下载
";
print_r($_SERVER);
echo "
\n"; if (function_exists('getallheaders')) { echo "
";
    print_r(getallheaders());
    echo "
"; } ?>

为什么 phpinfo() 不显示请求头?这是设计使然

phpinfo() 的定位是“环境诊断”,不是“请求调试”。它的输出内容由 PHP 内核在启动阶段静态生成,不依赖于 SAPI 层传入的请求数据。这意味着:

  • 无论你用 GET、POST、PUT 还是带 JWT 的请求访问,phpinfo() 输出都一样
  • 它不读取 $_GET$_POST$_COOKIE$_SERVER 等超全局变量,也不调用任何用户态逻辑
  • 性能上极轻量——几乎不触发任何运行时开销,这也是它被广泛用于探活、版本探测的原因

所以别指望靠修改 php.ini 或加参数让 phpinfo() 显示请求头。它压根没这个能力,也不是它的职责。

安全提醒:线上禁用 phpinfo(),且别用它查敏感头

很多开发者习惯上传临时 phpinfo.php 查环境,但容易忽略两点:

  • 如果服务器未限制访问,攻击者可直接看到 PHP 版本、已启用扩展(如 opensslgd)、disable_functions 列表、甚至 open_basedir 路径 —— 这些都是漏洞利用的关键线索
  • 即使你真用 $_SERVER 打印请求头,也要注意:某些头可能含敏感信息(如 Authorization: Bearer xxxX-API-Key),直接输出到 HTML 可能造成泄露

真正需要查请求头时,优先用 error_log(print_r(getallheaders(), true), 3, '/tmp/req.log') 记日志,而不是回显到页面。

相关专题

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

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

2648

2023.09.01

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

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

1657

2023.10.11

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

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

1515

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数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

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

1234

2023.11.03

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

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

1468

2023.11.09

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

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

1306

2023.11.13

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

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

72

2026.01.16

热门下载

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

精品课程

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

共137课时 | 8.8万人学习

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

共6课时 | 7.9万人学习

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

共13课时 | 0.9万人学习

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

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