phpMyAdmin v4.8.1 文件包含漏洞

本地搭建 phpMyAdmin v4.8.1 的环境。

既然是审计文件包含漏洞,那么我们只需要关注 include()、include_once()、require()、require_once() 这4个函数即可。

用Seay审计工具查找一下:

image.png

搜索的结果中,我们重点关注 include 包含的文件是可控的条目,其他include 固定文件的可以先忽略。
如上图,index.php 文件中有一处包含的文件名,是从请求参数中获取的,于是跟进去看看:

image.png

可以看到,target参数值,要满足以下条件,才能被包含:

(1)是一个非空字符串;
(2)不能以 index 开头;
(3)不能在黑名单数组 $target_blacklist 中;
(4)要满足 checkPageValidity() 函数

查看 checkPageValidity() 函数:

image.png

可以看到,该函数中有3个地方会返回true,它们最终都是判断变量 $_page 是否在 白名单数组 $whitelist 中。

其中白名单数组部分值如下:

image.png

先看第一个返回true的地方:

image.png

这里传入的未经任何处理的 $page 进行判断是否在白名单中,因此这里是无法进行绕过的。
然后看第二个返回true的地方:

image.png

其中,
mb_strpos是查找字符串(参数二)在目标字符串(参数一)中第一次出现的位置;
mb_substr则是截取从某位置start(参数二)开始往后截取长度为length(参数三) 的子字符串。
所以这里可以通过传入如: db_sql.php?/../../../../../../windows/system.ini 的方式来绕过白名单限制。
所以这里 checkPageValidity() 函数返回后,包含的形式为: include 'db_sql.php?/../../../../../../windows/system.ini',但 php会把问号? 后面的内容当做是 db_sql.php 的传入参数去处理,因此这里无法实现跨路径包含。

再来看第三个返回true的地方:

image.png

可以看到这里多了 urldecode() 函数,我们可以利用双重编码来进行绕过,
也就是将问号? 进行两次 URL编码,变为 %253f。
首先 %253f 被传入后,先会被自动URL解码一次,变为 %3f,然后经过 urldecode() 再解码一次,就变成了原先的问号?,从而绕过了白名单的限制。
最终文件包含时就是:include 'db_sql.php%3f/../../../../../../windows/system.ini' 这样的格式,如此就能包含任意文件了,如图:

image.png

如果要进一步利用,进行getshell,可以往数据库里创建表,然后往表里写上一句话木马。


文件包含漏洞的挖掘技巧总结:

  • 因为文件包含漏洞主要是对包含函数的地方处理不当造成的,所以我们可以针对性的对 include()、include_once()、require()、require_once() 函数 调用的地方进行审计。

文件包含漏洞的防御

  • 没有必要的情况下,设置 allow_url_include 和 allow_url_fopen 为关闭;
  • 建议假定所有输入都是可疑的,尝试对所有输入提交可能可能包含的文件地址,包括服务器本地文件及远程文件,进行严格的检查,参数中不允许出现../之类的目录跳转符。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,179评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,229评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,032评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,533评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,531评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,539评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,916评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,813评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,568评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,654评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,354评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,918评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,152评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,852评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,378评论 2 342

推荐阅读更多精彩内容

  • LFI、RFI、PHP封装协议安全问题学习 本文希望分享一些本地文件包含、远程文件包含、PHP的封装协议(伪协议)...
    Otis4631阅读 2,335评论 0 0
  • php面试题及答案(转载)收藏 基础题: 1.表单中 get与post提交方法的区别? 答:get是发送请求HTT...
    积_渐阅读 1,623评论 0 37
  • 自己做dede的开发时间也比较长了,基本上常用的函数都知道在哪个文件里面,但是时间一长,也有点模糊了,俗话说:好记...
    大刘的英语世界阅读 1,668评论 1 9
  • 考试,这个我们学习时代都要面临的事情,甚至工作时期,我们都要面临的事情,你的绩效的考核,你的企业知识掌握的如何等等...
    帝天宇阅读 1,617评论 41 68
  • 这里没有诗和远方,只有苟且! 一人一包一张票, 一城一景一心情, 一地一游一行程, 一心一意一辈子; 背上背包,踏...
    不变的永恒阅读 172评论 0 0