【安全漏洞】一次前台任意文件下载漏洞挖掘

1、起因

日常闲逛,翻到了某后台系统

先是日常手法操作了一番,弱口令走起

admin/123456 yyds!

U1s1,这个后台功能点少的可怜,文件上传点更是别想

不过那个备份管理的界面引起了我的兴趣,似乎有点意思

filename参数后面直接跟上了文件名,这很难让人不怀疑存在任意下载漏洞

抓包,放到burp中,发现果然存在任意文件下载

2、经过

经过fofa收集,我发现这是一个小通用,正当我打算兴致勃勃的打一发别的目标时,却发现这只是个后台洞,backup功能点需要管理员权限

直接302跳转了,晕

运用了常规手法,也bypass失败了

好了,此处漏洞挖掘到此结束

身为一个有菜又爱玩的家伙,我怎么可能轻言放弃呢?

本来打算批量扫备份拿源码,但后面发现,github的链接就在后台介绍处。。。

好家伙,我直呼好家伙,真是踏破铁鞋无觅处

拿到源码,赶紧在本地翻配置文件

spring+shiro的典型组合,嗯,刚好没学到过

凭着典型的脚本小子的思想,我考虑到了shiro的权限分配的较死,从逻辑层绕过估计是中彩票

想到f12sec有位师傅发表过shiro权限绕过的文章,可以利用shiro权限绕过,达到前台任意下载

但是尝试了网上公开的几种exp,发现均失败了

/;/------>302跳转

/;a/------>302跳转

末尾加上"/"------>302跳转

/fdsf;/../------>302跳转

怎么回事小老弟,我的200呢w(゚Д゚)w

最后,发现是我的姿势错了,在https://www.freebuf.com/vuls/231909.html中,我找到了答案

先了解点前置知识(大佬绕过):

Shiro的URL路径表达式为Ant 格式,路径通配符支持?***。

?:匹配一个字符

*:匹配零个或多个字符串

**:匹配路径中的零个或多个路径

上面的文章里解释的很清楚了,如果URI中存在;号的话,则会删除其后面的所有字符。/fdsf;/../hello/1/最终也就变成了/fdsf。

而我们这款web应用遇到不符合的目录就直接跳转了,所以,想要利用这个权限绕过,必须要有以下条件

1、存在,并且是anon权限的目录

2、要以路径通配符**结尾

很幸运,这款web应用中就有这样的目录

经过测试,images目录可行

然后手动构造,burp发包,芜湖,成功前台任意下载!


3、结果

很多对漏洞的理解是基于想象的,如果有不妥当之处,请各位大佬指出嘿嘿

另外我这边整理了一些最新的【网络安全学习资料·攻略】

你可能感兴趣的:(【安全漏洞】一次前台任意文件下载漏洞挖掘)