0

0

PHP文件包含:跨Web根目录外部文件的安全与动态引用实践

DDD

DDD

发布时间:2025-09-16 16:39:00

|

911人浏览过

|

来源于php中文网

原创

PHP文件包含:跨Web根目录外部文件的安全与动态引用实践

本文探讨了在PHP项目中如何安全且动态地包含位于Web根目录(如public_html)之外的配置文件。通过利用$_SERVER['DOCUMENT_ROOT']超全局变量结合相对路径导航符../,我们可以构建出独立于当前脚本位置的绝对文件路径,从而实现跨目录的可靠文件引用,增强应用程序的安全性与可维护性。

动态文件包含的挑战

php web开发中,经常需要包含一些公共文件,例如数据库连接配置、常量定义或通用函数库。为了安全起见,尤其是涉及敏感信息(如数据库凭证)的配置文件,通常建议将其放置在web服务器的公开可访问目录(如public_html或www)之外。这样做可以防止用户通过浏览器直接访问这些文件,即使web服务器配置错误或存在解析漏洞,也能提供额外的保护层。

然而,当文件位于Web根目录之外或包含脚本位于不同深度时,传统的相对路径包含方法(如../filename.php或../../filename.php)会变得非常繁琐且易出错。脚本所在的目录深度每改变一次,相对路径就需要相应调整,这极大地降低了代码的可维护性和可移植性。例如:

// 如果当前脚本在 public_html/folder1/script.php
// 且要包含的文件在 public_html 的上一级目录
include '../../filename.php';

// 如果当前脚本在 public_html/folder1/folder2/script.php
// 相同的包含文件就需要这样写
include '../../../filename.php';

这种依赖于脚本相对位置的路径,在项目结构调整时,往往需要全局搜索和替换,效率低下且容易遗漏。

解决方案:利用$_SERVER['DOCUMENT_ROOT']

PHP提供了一个名为$_SERVER['DOCUMENT_ROOT']的超全局变量,它包含了Web服务器为当前脚本定义的文档根目录的绝对路径。例如,如果你的Web根目录是/var/www/html,那么$_SERVER['DOCUMENT_ROOT']的值就是/var/www/html。

结合这个绝对路径和相对路径导航符../,我们可以构建出一个无论当前脚本位于何处都能准确指向目标文件的绝对路径。

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

核心方法

要包含一个位于public_html(即DOCUMENT_ROOT)上一级目录的文件,可以使用以下结构:

include "{$_SERVER['DOCUMENT_ROOT']}/../filename.php";

工作原理分析:

  1. $_SERVER['DOCUMENT_ROOT']:首先获取到Web服务器的文档根目录的绝对路径,例如 /var/www/html。
  2. /../:紧接着,我们使用/../。在文件系统中,..表示当前目录的父目录。因此,$_SERVER['DOCUMENT_ROOT']加上/../,就相当于从文档根目录向上移动一层。例如,/var/www/html/../ 实际上指向了 /var/www/。
  3. filename.php:最后,我们拼接上要包含的文件名。

通过这种方式,无论你的脚本文件是位于public_html/index.php,还是public_html/subfolder/script.php,甚至是public_html/another/deep/folder/processor.php,上述include语句都能正确地找到并包含位于/var/www/filename.php的文件。

ImgGood
ImgGood

免费在线AI照片编辑器

下载

示例代码

假设你的项目结构如下:

/var/www/
├── config.php        <-- 目标包含文件
└── html/             <-- Web根目录 (public_html, $_SERVER['DOCUMENT_ROOT'])
    ├── index.php
    └── admin/
        └── dashboard.php

config.php文件内容:

在index.php或admin/dashboard.php中包含config.php:

另一种实现方式

除了直接拼接/../,你也可以使用dirname()函数来获取父目录的路径:

include dirname($_SERVER["DOCUMENT_ROOT"]) . '/filename.php';

dirname($_SERVER["DOCUMENT_ROOT"])会返回$_SERVER["DOCUMENT_ROOT"]的父目录的路径,例如,如果$_SERVER["DOCUMENT_ROOT"]是/var/www/html,那么dirname()会返回/var/www。然后,再拼接上文件名。这两种方法殊途同归,效果一致。

注意事项与最佳实践

  1. 安全性提升: 将敏感配置文件放在Web根目录之外是最佳实践。即使Web服务器配置不当,无法阻止对.php文件的直接访问,这些文件也不会被直接暴露。
  2. 使用require_once或include_once: 对于关键的配置文件,建议使用require_once而不是include。require_once确保文件只被包含一次,避免重复定义错误,并且如果文件不存在,它会引发致命错误,阻止脚本继续执行,这对于依赖这些配置的应用程序是更安全的。
    require_once "{$_SERVER['DOCUMENT_ROOT']}/../config.php";
  3. 环境差异: $_SERVER['DOCUMENT_ROOT']的值由Web服务器(如Apache、Nginx)配置决定。在不同的服务器环境或开发环境中,其值可能不同,但上述方法仍然具有良好的通用性,因为它依赖的是服务器的配置而非硬编码路径。
  4. 路径的清晰性: 确保filename.php是准确的文件名,并且文件确实位于DOCUMENT_ROOT的上一级目录。如果文件在更深的层级,你需要相应地调整../的数量,例如../../filename.php表示向上两级。
  5. 替代方案(更高级): 对于大型或复杂的项目,可以考虑使用更高级的解决方案,如定义一个全局的根目录常量(例如通过入口文件设置),或使用Composer的自动加载功能结合PSR-4标准,或者利用框架提供的配置加载机制。

总结

通过巧妙地结合$_SERVER['DOCUMENT_ROOT']超全局变量和相对路径导航符../,PHP开发者可以构建出强大且灵活的文件包含机制。这种方法不仅解决了传统相对路径在多层级目录结构下维护困难的问题,更重要的是,它提供了一种将敏感配置文件安全地放置在Web根目录之外的有效手段,从而显著提升了Web应用程序的安全性和可维护性。在实际开发中,推荐将此方法作为包含外部配置文件的标准实践。

相关专题

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

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

2537

2023.09.01

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

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

1606

2023.10.11

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

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

1499

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

1416

2023.10.23

html怎么上传
html怎么上传

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

1234

2023.11.03

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

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

1445

2023.11.09

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

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

1306

2023.11.13

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

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

精品课程

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

共137课时 | 8.7万人学习

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

共6课时 | 7万人学习

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

共13课时 | 0.9万人学习

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

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