文件包含漏洞、DVWA-File Inclusion

本文介绍了文件包含漏洞的概念,详细阐述了PHP的include、require等函数的工作原理,并探讨了本地文件包含(LFI)和远程文件包含(RFI)。通过DVWA靶场演示了如何利用和防御文件包含漏洞,包括设置白名单、限制包含目录、严格检查输入等措施。
摘要由CSDN通过智能技术生成

文件包含漏洞

什么是文件包含漏洞?
攻击者利用包含的特性,加上应用本身对文件(包含)控制不严格,最终造成攻击者进行任意文件包含。
(包含的文件会被当做脚本文件来解析)

一句话来说就是:文件包含并不属于漏洞,但是,由于对包含进来的文件不可控,导致了文件包含漏洞的产生。

包含文件很有用,可以简化代码
文件包含分为本地和远程文件包含(需要allow_url_include=On)
本地文件包含LFI
远程文件包含RFI

函数解析
这里我们需要了解4个PHP的函数

include:使用include引用外部文件时,只有代码执行到include代码段时,调用的外部文件才会被引用并读取,当引用的文件发生错误时,系统只会给出警告错误,而整个php文件会继续执行。

require:在php文件被执行之前,php解析器会用被引用的文件的全部内容替换require语句,然后与require语句之外的其他语句组成个新的php文件,最好按新的php文件执行程序代码。

include_once:
使用include_once会在导入文件前先检测该文件是否在该页面的其他部分被引用过,如果有,则不会重复引用该文件,程序只能引用一次。(要导入的文件中存在一些自定义函数,那么如果在同一个程序中重复导入这个文件,在第二次导入时便会发生错误,因为php不允许相同名称的函数被重复声明)

require_once:
require_once语句是require语句的延伸,他的功能与

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值