php 绕过扩展名检查,文件上传漏洞---后缀名绕过&原理

0x00 前言

今天来讨论文件上传漏洞之后缀名绕过。通常在实际生产过程中,并不会有直接可以上传.php等明显的可直接执行的文件,所以在这里我记录下后缀名绕过的原理和方法。

0x01 绕过方法

首先准备三个文件后缀名分别为.php .php3 .php30 如图:2bd6208b43e9fede4f624eb623d3545e.png

上传.php的情况下发现,有了黑名单检验,不能上传.php结尾的文件,这是大部分实际情况下会遇到的问题。df40e7de247c89df88a66af108b62637.png

但是当我们把.php3和.php30上传时发现都能成功上传,但是发现.php30的文件访问时直接将文件内容以字符显示了出来,所以.php30不能用于后缀名绕过.php3可以。51e1476e30f91ffd61b08f6874ac704b.png

2a01f552fc4e939bae665eb17a49beb5.png

aecfd12280ed5115dacef92245d1bcd5.png

7cb92955f7e1c37760e27c3bfbfeb48f.png

通过菜刀检验发现.php3可以获取后台目录fb39793803d4f7953fe9773b7982ec72.png

31a72ac84493bb8dac598b3b12143f54.png

0x02 原理

部分服务仅根据后缀、上传时的信息或Magic Header来判断文件类型,此时可以绕过。以Apache为例 会通过通过后缀名判断使用哪种解析器

在apache的配置文件中有这么一段代码22d00f697d3d6bffd895a621dfbe471f.png

可以看到如果后缀名是.php .php3 4 5 .pht phtml 等 都是指向php解析器的 可以通过这些后缀名绕过后缀名检验

0x03 部分语言可选绕过后缀名

php由于历史原因,部分解释器可能支持符合正则 /ph(p[2-7]?|t(ml)?)/ 的后缀,如 php / php5 / pht / phtml / shtml / pwml / phtm 等 可在禁止上传php文件时测试该类型。

jsp引擎则可能会解析 jspx / jspf / jspa / jsw / jsv / jtml 等后缀,asp支持 asa / asax / cer / cdx / aspx / ascx / ashx / asmx / asp{80-90} 等后缀。

除了这些绕过,其他的后缀同样可能带来问题,如 vbs / asis / sh / reg / cgi / exe / dll / com / bat / pl / cfc / cfm / ini 等。

0x04 防范措施

使用白名单限制上传文件的类型

使用更严格的文件类型检查方式

0x05 END

以上就是后缀名绕过的知识原理了。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
文件类型校验是确保文件上传的安全性和准确性的重要步骤。其中,文件类型校验可以通过检查文件名和文件头信息(也称为魔术数字)来实现。文件头信息是一些预定义的字节序列,用于标识特定的文件类型。 常见的文件头信息及其对应的文件类型如下: - JPEG:FF D8 FF - PNG:89 50 4E 47 0D 0A 1A 0A - GIF:47 49 46 38 39 61 或者 47 49 46 38 37 61 - PDF:25 50 44 46 2D 或者 25 50 44 46 2E - MP3:FF FB 或者 FF F3 文件头信息并不是绝对可靠的,因为它们可以被修改或伪造。为了增强文件类型校验的安全性,可以结合文件后缀名和MIME-TYPE来进行校验。 文件后缀名是指文件名中最后一个“.”后面的字符串,例如“.jpg”、“.png”等。MIME-TYPE是指互联网媒体类型,用于标识文件的类型。常见的MIME-TYPE及其对应的文件类型如下: - image/jpeg:JPEG格式的图片 - image/png:PNG格式的图片 - image/gif:GIF格式的图片 - application/pdf:PDF格式的文档 - audio/mpeg:MP3格式的音频 在进行文件上传时,可以通过检查文件后缀名和MIME-TYPE来确保上传的文件类型正确。具体实现方法可以参考以下步骤: 1. 获取上传文件的文件名和文件头信息。 2. 根据文件头信息判断文件类型是否正确。 3. 根据文件名获取文件后缀名,与文件头信息中的文件类型进行比较,确保文件类型一致。 4. 根据文件类型获取对应的MIME-TYPE,与上传的文件MIME-TYPE进行比较,确保MIME-TYPE一致。 如果文件类型校验不通过,可以拒绝上传或者给出相应的提示信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值