0

0

PHP探针如何设置访问权限_PHP探针设置访问权限方法【要点】

絕刀狂花

絕刀狂花

发布时间:2026-01-19 20:13:02

|

730人浏览过

|

来源于php中文网

原创

PHP探针文件默认不可直接放服务器根目录,因其无内置鉴权,易导致敏感信息泄露;应移出Web根目录,通过带Token和IP校验的入口脚本间接调用,并配合Web服务器配置禁止直接访问。

php探针如何设置访问权限_php探针设置访问权限方法【要点】

PHP探针文件默认不能直接放服务器根目录

绝大多数 PHP 探针(如 phpinfo.phptz.php、各类一键检测脚本)本质是裸露系统信息的诊断页,没有内置鉴权逻辑。一旦上传到 Web 可访问路径,任何知道 URL 的人都能查看服务器配置、PHP 版本、扩展列表、环境变量甚至 $_SERVER 中的敏感路径。这不是“要不要设权限”的问题,而是“不设就等于公开暴露”。

  • 不要用 .htaccess 简单 deny all 后再靠 IP 白名单——很多主机不支持或规则被忽略
  • 避免把探针放在 /public/www/htdocs 这类默认 Web 根下
  • 更稳妥的做法:放在 Web 根目录之外,通过 CLI 或带参数的代理脚本间接调用(见下一条)

用 require + 权限判断替代直接访问探针文件

真正的权限控制应发生在 PHP 层,而不是靠 Web 服务器拦截。典型做法是写一个带校验的入口脚本,只在满足条件时才 require 探针主体。

 
  • phpinfo.php 文件本身应移出 Web 根目录(例如放到 /home/user/tools/phpinfo.php),或至少加 .php 后缀并确保 Web 服务器不解析非标准后缀
  • Token 不要硬编码在生产环境,可用 $_ENV['PROBE_TOKEN'] 从环境变量读取
  • IP 判断仅适用于内网或固定出口场景;公网部署必须配合登录态或一次性令牌

Apache/Nginx 下禁止直接访问探针文件的配置项

即使做了 PHP 层校验,也建议叠加 Web 服务器级防护,防止绕过或误传。

Apache(放在 .htaccess 或虚拟主机配置中):

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

无涯·问知
无涯·问知

无涯·问知,是一款基于星环大模型底座,结合个人知识库、企业知识库、法律法规、财经等多种知识源的企业级垂直领域问答产品

下载

    Require all denied

Nginx(server 块内):

location ~* ^/(phpinfo|tz|probe)\.php$ {
    deny all;
}
  • 注意 Nginx 的正则匹配需覆盖所有常见探针文件名变体(info.phptest.phpenv.php
  • Apache 的 对大小写敏感,PHPINFO.PHP 可能逃逸,建议加 配合正则
  • 这些规则只阻断 HTTP 访问,不影响 CLI 或 require 调用

探针输出中敏感信息的过滤处理

有些探针会打印 $_ENVphp_ini_loaded_file()getcwd() 等结果,可能泄露绝对路径或数据库凭证。不能只靠访问控制,还得清理内容。

例如修改 phpinfo.php 中关键段落:

// 过滤掉包含敏感关键词的行
$html = pregreplace('/.*?(?:PWD|HOME|PATH|DB|SECRET|KEY).*?<\/tr>/i', '', $html);
echo $html;
?>
  • 正则过滤只是补救,优先从源头避免输出——比如不用 phpinfo(INFO_ENVIRONMENT),改用 phpinfo(INFO_GENERAL | INFO_MODULES)
  • 某些探针会主动 dump $_SERVER,务必检查源码并注释或删减相关 print_r()
  • 如果用了 Composer 包管理的探针(如 spatie/php-version-checker),确认其未启用调试模式

实际部署时最容易被忽略的是:探针文件权限设为 644 且放在 Web 目录下,同时又没做任何 PHP 层校验——这种组合等于把服务器快照贴在门口。真正安全的探针,从来不是“藏起来”,而是“没授权就根本不会执行”。

相关专题

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

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

2684

2023.09.01

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

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

1661

2023.10.11

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

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

1518

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

1419

2023.10.23

html怎么上传
html怎么上传

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

1235

2023.11.03

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

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

1488

2023.11.09

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

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

1306

2023.11.13

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

php8,我来也
php8,我来也

共35课时 | 32万人学习

千锋PHP-HTML入门及实战视频教程
千锋PHP-HTML入门及实战视频教程

共18课时 | 3.3万人学习

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

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