php知识点总结(从一道CTF题目谈PHP中的命令执行)
php知识点总结(从一道CTF题目谈PHP中的命令执行)
2024-11-05 09:16:02  作者:伱爹临死前  网址:https://m.xinb2b.cn/life/bwq162065.html

原创 Xenny 合天智汇

快睡的时候,打开B站发现有位用户留言,大意就是让我帮忙看一道题,正好当时有空,于是就打开了他发的链接,代码如下


很明显是一道PHP代码审计的题目,而且只需要绕过第三行的if即可进行任意命令执行。

解决思路

看了代码之后觉得是道普通的题目,对于/a-zA-Z/这个正则表达式,我们可以利用PHP动态函数的特性,构造出字符串即可。

对于想要的字符串,我们可以通过以下三种方式来构造:

1. 异或

对于PHP中的字符串,两个字符串异或的结果是将两个字符串逐位异或,返回一个新字符串。那么我们便可以使用此特性进行构造。

例如我们需要构造phpinfo,则可以用脚本得到('0302181', '@[@[_^^')这两个字符串,脚本如下:


其中valid是可用的字符,answer是我们需要构造的字符串。那么我们得到了这个字符串,又该如何去执行呢。我们可以通过一个变量存储两字符串异或后的值,再让这个变量进行动态函数执行即可,而变量的话因为PHP的变量命名规则和C语言相同,可以使用下划线进行命名,如下:


2. 取反构造

和第一种类似,都是基于PHP字符串位运算的特点(会逐位进行位运算)。而取反构造某些情况比异或构造要方便,因为异或的情况某些字符是无法直接通过其他字符进行异或构造的,而取反却可以利用汉字或者其他特殊字符进行构造(不会有题目会限制某个汉字吧)。比如字母s我们可以通过~('和'{2})得到。而这个时候如果要用异或去构造的话,你得找到两个异或值为s的特殊字符。

取反构造的脚本和异或构造类似,在此不再给出。

3. 自增构造

` 'a' == 'b'`

这个特点是利用了PHP是弱类型语言的特性,在对变量进行操作的时候,PHP会隐式的转换其变量类型,很多代码审计的题目也是利用了这一特性。

遇到障碍

有了上面的思路后,而且也成功执行了phpinfo(),下一步是不是就可以直接构造命令执行函数去进行读取文件,当时我也是这么想的,于是我构造了passthru(), system(), shell_exec(), exec()等函数,都受到了阻碍,没有回显,通过进一步的调试之后发现是禁用了这些函数(通过在函数后面加一个打印函数观察是否执行)。

在这里我停留了很久,试过打印$GLOBALS等都没有任何有用的信息。最后通过使用glob()函数进行目录扫描,发现了flag.php文件,以及file_get_contents()进行获取,最终的payload如下

?mess=$_="`0123"^"?`~``";${$_}[_](${$_}[__]);&_=assert&__=print_r(base64_encode(file_put_contents("flag.php")))


最后再将其界面就可以得到最终的flag了。在最终的payload中我没有去一个一个的构造字符串异或,因为那太长了,而是构造了一个$_POST[_]($_POST[__])的动态函数,这样就可以在其他参数位置直接写函数了。

深入分析

题目到这里就结束了,其实并没有多难,首先是通过特性去构造动态函数,然后发现了命令执行被禁用之后,能够知道使用其他函数去进行获取信息就行了。但是做完这道题后,不仅引发了我的思考,PHP中的命令执行就只有这些方式了吗,肯定不是。于是,我总结了几种新的命令执行技巧供大家参考。

1. 当打印函数被禁用时

如果没有了打印函数,意味着你无法看到回显,这时候即使命令执行成功了你也无法得到信息,这个时候你就得利用其他方式去获取回显了。

首先是网上很多blog使用的方式,phpinfo如果发现开启了curl,或者其他文件传输扩展的的话,可以自建一个靶机,将所有访问信息存入数据库或是文件,然后将回显信息发送到你的靶机地址,这样你去看日志就可以了,这种方式不是很方便而且有一定的局限性。这里我要介绍的是一种新的方式。

如果你使用过Django或者jsp开发web的话,你肯定知道输出一个变量可以使用{{xxx}}或是<%=xxx%>的方式,那么在PHP中是否也有这种方式呢,答案是肯定的,PHP中的<?=xxx?>就可以将一个变量输出,那么如果使用它呢,你只需要构造如下的payload

valid = "1234567890!@$%^*(){}[];\'\",.<>/?-=_`~ "answer = "phpinfo"tmp1,tmp2 = '',''for c in answer: for i in valid: for j in valid: if (ord(i)^ord(j) == ord(c)): tmp1 = i tmp2 = j break else: continue breakprint(tmp1,tmp2)

这样就可以将变量$_里面的内容打印到屏幕上,而且关键的是这个输出方式默认是开启的,管理员很容易就忽视这个选项。所以在做题时不妨一试。

2. 其他的命令执行方式

当system,passthru等不能用时,网上会告诉你可以使用popen,proc_open这些管道命令去进行执行命令,当然这没有问题,而这里我向你介绍一种新方式,使用反引号,在PHP中,被两个反引号括起来的内容将会作为shell命令执行,并将输出信息返回,所以你可以构造下面的payload进行命令执行

$_=`ls`;

3. 不能使用数字字母的命令执行

当不能使用字母数字时,当然你可以使用上述的方式构造字符串进行执行,但是这里提供一些新东西,对于linux中的shell是支持正则表达式的,当你忘记某些字符时可以通过? % *来代替,经过测试,这里的匹配方式也是按照顺序进行匹配,所以你可以查看你的linux中/bin目录下面的顺序,来获取一些可以使用的命令,比如

/???/??? => /bin/cat

那么这样的话,如果要获取/var/www/html/index.php(你得感谢apache默认目录如此之深),则可以直接使用

/???/??? /???/???/????/?????.???

来获取

总结

这篇文章只是针对这道题而延展出的一些东西,在真正做题时,情况可能更加复杂,例如限制长度,限制参数等等情况,而我们的做法也不可能千篇一律,可能某些时候我们甚至会用到一些CVE漏洞。而本篇文章只是告诉读者一些可能以前没有见过的新东西。

那么本篇文章就到此结束了。

如果想更多系统的学习CTF,可点击“http://www.hetianlab.com/pages/CTFLaboratory.jsp”,进入CTF实验室学习,里面涵盖了6个题目类型系统的学习路径和实操环境。


声明:笔者初衷用于分享与普及网络知识,若读者因此作出任何危害网络安全行为后果自负,与合天智汇及原作者无关!

  • 给客户返点(客户的返佣会计应该如何做账)
  • 2024-11-05客户的返佣会计应该如何做账客户的返佣应该如何做账?答:常用的处理方式有以下两种:1、销售返利可以视为销售折扣,计入财务费用.借:银行存款财务费用贷:主营(其他)业务收入应交税费-应交增值税(销项税额)2、返佣出去的钱的做账借:。
  • 五大淡水湖 排名(最大淡水湖缩水66)
  • 2024-11-05最大淡水湖缩水66受持续高温天气影响,我国最大淡水湖江西鄱阳湖水位持续走低据国家卫星气象中心,8月18日,江西鄱阳湖水体面积约为1113平方公里(左下图),较2022年7月10日水体面积(右下图)减少了约66%,大概相。
  • 好看儿童节的手工贺卡独一无二(让娃学会表心意)
  • 2024-11-05让娃学会表心意简单的一张卡片,从孩子手上接过的那一刻,总是倍感幸福心形创意卡片用“心”是表达爱最直接最常用的方式用线串出来的心更加有爱哦!【步骤教程】在纸上先画出一个心,打上小孔,用线来回穿梭即可立体贺卡第一次打开。
  • 猫咪一旦出现五个症状(猫咪一旦出现这5个现象)
  • 2024-11-05猫咪一旦出现这5个现象我们人会有到老的一天,其实猫咪也是一样的,当到了某个年纪就开始慢慢老去那么主人要怎么判断猫咪是否已经老了呢?如果你家猫咪一旦出现下面的几个现象的话,其实就已经说明它已经步入老年期了,你家有吗?现象1、。
  • 如何简洁的讲营销策划ppt(如何打造超强战斗力的营销团队)
  • 2024-11-05如何打造超强战斗力的营销团队分享100企业增长案例、策略、方法,助力创业者少走弯路!每日更新,欢迎关注!内容黄金战队“团队常见6大问题”领导过于放权团队协作性不强主要成员不稳定沟通交流不顺阶段性裁员成员能力不均等黄金战队“10大。
  • 微信群收款操作步骤(微信群收款操作方法)
  • 2024-11-05微信群收款操作方法首先,点击打开微信,进入微信页面,然后点击-我在我的页面,点击-支付,进入支付界面然后在支付页面,点击-收付款在收付款界面,点击-群收款点击-选择聊天,选择要开启群付款的群聊然后选择收款总金额,收款人。
  • 囧妈徐峥电影混剪:贺岁片集体提档
  • 2024-11-05囧妈徐峥电影混剪:贺岁片集体提档1月20日中午,春节档六部大片之一《囧妈》突然官宣提档,1月24日就开始排片,比其他电影抢先了一步,没想到《囧妈》提档之后,《夺冠》、《熊出没》也立马跟上,同时爆料进一步更新,称后续还有一堆片要宣布提。
  • 小的成语100个(小成语大智慧)
  • 2024-11-05小成语大智慧这是一则大家都非常熟悉的故事了:楚国有个年轻人,得到一把宝剑,十分珍爱,每天都带在身上,常常把玩这一天,这位楚国人要乘船过江了楚国人靠在船舷边,又想起了他心爱的宝剑,便拿在手里仔细欣赏、把玩起来正在这。
  • 关于死鬼的故事(真实鬼故事之饿死鬼)
  • 2024-11-05真实鬼故事之饿死鬼真实鬼故事 之 饿死鬼人们常说经常走夜路就会遇到鬼,这事还真的发生了...                那是二十七年前的一个秋末冬出的季节,那年我大概六岁吧,小时侯家里穷,身为农民的爸爸靠倒腾点小买。
  • 考研之前需要做哪些准备(考研注意事项有哪些)
  • 2024-11-05考研注意事项有哪些在高等教育普及化阶段,大学生变得越来越“不值钱”了,无论是用人单位还是社会舆论对于学历的要求越来越高为了提高学历,提升就业竞争力,越来越多的大学生走上了考研这条路如果说高考是一个独木桥,那么考研就是一。
  • 真实的古代声音:历史上鲜为人知的几种声音
  • 2024-11-05真实的古代声音:历史上鲜为人知的几种声音俗话说:世界之大,无奇不有音乐的传承也是带着历史的洪流渐渐发展,在历史之下,渐渐生成了不同的乐器,不同的派系,有些乐器也因此在历史中被人淡忘了这些小众乐器,你知道哪些呢?萨朗吉,这是一种来自印度的乐器。