freeBuf
主站

分类

云安全 AI安全 开发安全 终端安全 数据安全 Web安全 基础安全 企业安全 关基安全 移动安全 系统安全 其他安全

特色

热点 工具 漏洞 人物志 活动 安全招聘 攻防演练 政策法规

点我创作

试试在FreeBuf发布您的第一篇文章 让安全圈留下您的足迹
我知道了

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

业务逻辑漏洞探索之上传漏洞
交个朋友 2019-01-23 11:04:13 318288

本文中提供的例子均来自网络已公开测试的例子,仅供参考。

斗哥又带着业务逻辑漏洞来找你们探讨啦,这次的内容是上传漏洞。

许多网站都允许用户自行上传照片、电子档材料,如果上传功能没有做好防护措施,就存在巨大的安全风险。如果web应用在文件上传过程中没有对文件的安全性进行有效的校验,攻击者可以通过上传webshell等恶意文件对服务器进行攻击,这种情况下认为系统存在文件上传漏洞。

以下是斗哥总结的一部分上传漏洞的场景,如果你有积累别的上传绕过姿势也可以和斗哥探讨探讨~

探讨.webp.jpg

1.无任何过滤

现在大部分的研发人员只要有一点安全意识基本上都会对上传功能进行一定的限制,但也不排除仍有网站的上传功能没有任何的防护。对于没有任何防护措施的上传功能,就可以任意上传恶意文件啦。

举个栗子:

a). 某站点对文件上传无任何的防护。

防护.webp.jpg

b). 找到对应的文件上传功能。

上传.webp.jpg

c). 直接上传一个恶意文件,不用修改后缀名。

缀名.webp.jpg

d). 文件上传成功后会返回上传的相对路径。

相对.webp.jpg

e). 补全上传路径后访问上传的webshell,就可以对服务器进行控制。

控制.webp.jpg

2.客户端校验绕过

客户端检测最典型的方式就是JavaScript检测,由于JavaScript在客户端执行的特点,可以通过修改客户端代码或先上传符合要求的文件再在上传过程使用BURP等工具篡改文件等方式来绕过。

举个栗子:

a). 某系统存在上传漏洞。

系统.webp.jpg

b). 将shell文件后缀改为允许上传的文件进行上传,再通过burp进行拦截改后缀,可顺利上传成功。

顺利.webp.jpg

c). 访问shell可以控制整个服务器,获取服务器权限。

权限 1.webp.jpg权限 2.webp.jpg


3.服务端校验绕过

1.MIME绕过

MIME(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型。是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自动使用指定应用程序来打开。标准的文件上传组件中会自动上传文件的MIME类型,但是由于MIME类型是从客户端传递的,修改也不影响文件正常运行,因此通过BURP拦截和修改MIME类型可以轻易绕过此类检测。

举个栗子:

a). 某系统使用abcedit编辑器存在mime绕过上传漏洞。

绕过.webp.jpg

b).上传功能要求只能上传图片格式文件,我们上传txt文件,使用抓包工具进行拦截。

抓包.webp.jpg

c).将Content-Type改为gif的mime格式。

格式.webp.jpg

d). 成功上传txt绕过mime的限制。

t  1.webp.jpg

2.  文件内容绕过

针对文件头和文件内容检测通常有两种方式,白名单的方式是检测上传的文件中是否有白名单类型文件的文件头等内容特征信息,满足要求方能上传。黑名单是检测一些WEBshell的特征,如果包含相关特征就不允许上传。针对白名单检测,可以在满足要求的文件后插入木马脚本语句来绕过。而黑名单则可以通过对关键函数的各类混淆变化来绕过。

举个栗子:

a). 某系统存在上传漏洞,找到相关上传功能。

相关.webp.jpg

b) . 在正常的一张图片中加入一句话木马,制作成图片马,然后将图片马进行上传。

图片马.webp.jpg

c). 发现文件绕过内容检测上传成功,并且能连上shell,可控制整台服务器。

发现.webp.jpg

d). 可以进一步控制内网。

控制.webp.jpg

3.  扩展名绕过

正常情况下如果用户上传的网页木马文件不是以响应的脚本文件扩展名上传的,则无法正常运行,达不到控制网站服务器的目的。然而,如果对文件扩展名检测的实现方式不当的话仍然存在风险。文件扩展名检测通常分为黑名单检测和白名单检测两种,针对黑名单绕过方式有使用不常见的扩展名、大小写绕过及特殊字符结尾等,针对白名单绕过方式可以使用截断绕过、解析漏洞等进行绕过。

举个栗子:

A. 特殊扩展名

a) .某个安全狗软件存在上传漏洞可进行绕过,正常上传一个php的文件会被拦截。

b).在文件后缀名后加上一个空格和一个小数点,发现可以绕过上传的限制。

限制 1.webp.jpg限制 2.webp.jpg

c). 可以执行任意命令。

执行.webp.jpg

B.  截断漏洞

a). 某系统存在上传漏洞。

上传.webp.jpg


b). 登陆后找到上传功能,上传的时候进行抓包,修改后缀,加上url编码后的%00,例如下面的修改为jtbx1.jsp%00.dat。

修改.webp.jpg

c). 上传文件后,可以访问shell进行控制服务器。

服务器.webp.jpg

4.修复建议

斗哥这次的总结就到这啦,如果你也有上传漏洞的绕过姿势可以留言告诉斗哥哦~

对于上传漏洞的话,斗哥还是要和程序猿小哥哥提点小建议:

1.对上传的文件的扩展名和文件报头信息在服务端与白名单对比,不符合白名单的不予保存。

2.上传过程不应传递目录或文件路径,使用预先设置路径列表中的匹配索引值,严禁泄露文件绝对路径。

3.对文件进行重命名,使用随机性好的文件目录和文件名进行保存。

4.上传文件的临时目录和保存目录不允许执行权限。

5. 有条件时可将保存在内容服务器或者数据库中。

0000.jpg

# 上传漏洞
免责声明
1.一般免责声明:本文所提供的技术信息仅供参考,不构成任何专业建议。读者应根据自身情况谨慎使用且应遵守《中华人民共和国网络安全法》,作者及发布平台不对因使用本文信息而导致的任何直接或间接责任或损失负责。
2. 适用性声明:文中技术内容可能不适用于所有情况或系统,在实际应用前请充分测试和评估。若因使用不当造成的任何问题,相关方不承担责任。
3. 更新声明:技术发展迅速,文章内容可能存在滞后性。读者需自行判断信息的时效性,因依据过时内容产生的后果,作者及发布平台不承担责任。
本文为 交个朋友 独立观点,未经授权禁止转载。
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
从0到1学技术
交个朋友 LV.3
这个号主要用来交个朋友
  • 81 文章数
  • 448 关注者
全网最全的Cobalt Strike使用教程-进阶篇
2021-09-28
全网最全的Cobalt Strike使用教程系列-基础篇
2021-09-27
“百香果”内网安全沙盘2.0bate版使用指南-进阶篇
2021-04-28