本文共 1214 字,大约阅读时间需要 4 分钟。
伙伴们有什么疑问, 或者我写的有什么纰漏可以和我说呀,评论或者私信都是可以的。相互交流。学的更快!!!
第一次写博客,,慌得很,先看源码压压惊吧 ( ̄_ ̄|||)
是一道反序列化的题,然后从ini_set能够看出来是包含session的类型,但是又不同于最最基础的那种session反序列化的题目。(这个先这样,,等我做做那种题目之后再来修改一下。。。)
这个题没有接收SESSION变量,那么就属于这个类型在PHP中有一个upload_process机制,会自动在$_SESSION中创建一个键值对,这个值刚好是我们用户可以控制的那部分,可以看下官方的描述
讲真的,我没看明白。但是我找到了他的名字,学工程的嘛,会用就行(找台阶)
当我们POST一个同名变量的时候,就能够添加一个我们可以控制键值的键值对了,嗯。
随便get一个phpinfo参数,先看看phpinfo有什么信息。
可以看到默认的session引擎时php_serialize但是题目使用的引擎时php。也就是我们放入的时候是用的php方法,取出来的时候用的php_serialize方法。 左边是局部变量,右边是全局变量 啰嗦的够多了,开始操作:

上传burp抓包,修改filename。。。这里这里,为什么是修改filename我也不清楚哎,,,等回头再看看

找到文件后,再找到目录就可以看到flag了。找目录的方法也有二:

这里!!我找到为什么要修改filename了。。
。。。就是把filename赋值到session中,其实说起来也挺无语的,没有个说服力。。 而后,就这样,看图嘛🐎
用file_get_contents函数将文件内容写入一个字符串中,然后打印出来 
参考:https://www.cnblogs.com/zzjdbk/p/12995217.html