因str_replace导致的注入问题总结


Posted in PHP onAugust 08, 2019

研究了下replace的注入安全问题。

一般sql注入的过滤方式就是引用addslashes函数进行过滤。

因str_replace导致的注入问题总结

他会把注入的单引号转换成\',把双引号转换成\",反斜杠会转换成\\等

写一段php代码:

<!DOCTYPE html>
<html>
<head>
 <title></title>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
</head>
<body>
<?php
 $x=$_GET['x'];
 $id=str_replace(addslashes($_GET['y']),'',addslashes($x));
 echo "过滤后:".addslashes($x)."<br/>";
 echo "replace替换绕过:".$id."<br/>";
 $conn = mysql_connect('127.0.0.1','root','root');//连接mysql数据库 
 mysql_select_db('test',$conn);//选择$conn连接请求下的test数据库名 
 $sql = "select * from user1 where id='$id'";//定义sql语句并组合变量id 
 $result = mysql_query($sql);//执行sql语句并返回给变量result 
 while($row = mysql_fetch_array($result)){//遍历数组数据并显示 
  echo "ID".$row['id']."</br>"; 
  echo "用户名".$row['name']."</br>"; 
 } 
 mysql_close($conn);//关闭数据库连接 
 echo "<hr>"; 
 echo "当前语句:"; 
 echo $sql;
?>
</body>
</html>

发现是引用了addslashes函数的:

因str_replace导致的注入问题总结

一个单引号或者双引号直接被转义,字符串注入到这里基本上gg了。没戏了。

addslashes的问题:

addslashes会把%00转换成\0

addslashes会把单引号(')转换成\'

因为使用了str_replace函数,会替换那么输入%00' 就被addslashes函数自动添加\0\',然后我们匹配0,就变成了\\'再次转换成\',单引号成功逃逸。

<?php
 echo str_replace("0","","\0\'")
?>

\0\'就是我们输入的%00'

会输出:

因str_replace导致的注入问题总结

那么知道了原理根据上面的php代码构造合适的sql语句绕过addslashes过滤

因str_replace导致的注入问题总结

单引号成功逃逸,这里不能用单引号闭合了,后门闭合会被过滤那么直接:

返回真:

因str_replace导致的注入问题总结

返回假

因str_replace导致的注入问题总结

那么想出数据就很方便。这里不演示了常规语句就行了。

模拟环境没啥意思,去网上找了个别人的代码审计文章,找到了一个雨牛挖的cmseasy的str_replace绕过注入的真实案例

2014年的漏洞,cmseasy相关版本网上已经找不到了,我改写了个cmseasy,方便测试这个replace注入:

cmseasy环境下载:链接: https://pan.baidu.com/s/1KgHaPxuB3UI36fyx4IbW9w 提取码: 7aj3

存在问题的目录lib/plugins/pay/alipay.php

第87行用了str_replace替换

因str_replace导致的注入问题总结

替换后的内容赋值给了$order_sn

往下看发现调用了check_money函数,跟踪下这个函数查看内部实现:

uploads/lib/table/pay.php

因str_replace导致的注入问题总结

先是赋值然后调用了getrow函数,跟进去看看:

uploads/lib/inc/table.php

因str_replace导致的注入问题总结

condition没有啥数据库操作后跟下面那个函数,跟踪下rec_select_one:

还在table.php文件下:

因str_replace导致的注入问题总结

跟下sql_select函数:

因str_replace导致的注入问题总结

被带入数据库查询:

默认echo $sql;是被注释的,解除注释方便查看sql语句:

因为str_replace的缘故,可以被绕过进行sql注入:

去除注释符,构造poc:

http://localhost/CmsEasy/uploads/index.php/?case=archive&act=respond&code=alipay&trade_status=WAIT_SELLER_SEND_GOODS

       POST:out_trade_no=11111%00'&subject=0

 sql语句报错存在sql注入

因str_replace导致的注入问题总结

那么修复方案是什么呢?

回到刚开始的alipay.php

第79行

因str_replace导致的注入问题总结

正则匹配下\'

然后再次访问:

直接跳转了不再停留了。

因str_replace导致的注入问题总结

修复方案:

function respond() {
  if (!empty($_POST)) {
   foreach($_POST as $key =>$data) {
    if(preg_match('/(=|<|>|\')/', $data)){
     return false;
    }
    $_GET[$key] = $data;
   }
  }

参考文章:https://wizardforcel.gitbooks.io/php-common-vulnerability/content/23.html

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

PHP 相关文章推荐
利用PHP创建动态图像
Oct 09 PHP
php数据库配置文件一般做法分享
Jul 07 PHP
破解.net程序(dll文件)编译和反编译方法
Jan 31 PHP
基于php在各种web服务器的运行模式详解
Jun 03 PHP
PHP实现今天是星期几的几种写法
Sep 26 PHP
php内核解析:PHP中的哈希表
Jan 30 PHP
PHP curl 抓取AJAX异步内容示例
Sep 09 PHP
PHP实现图片自动清理的方法
Jul 08 PHP
PHP页面转UTF-8中文编码乱码的解决办法
Oct 20 PHP
PHP简单判断iPhone、iPad、Android及PC设备的方法
Oct 11 PHP
php源码之将图片转化为data/base64数据流实例详解
Nov 27 PHP
php 截取GBK文档某个位置开始的n个字符方法
Mar 08 PHP
PHP goto语句用法实例
Aug 06 #PHP
Laravel 6 将新增为指定队列任务设置中间件的功能
Aug 06 #PHP
Yii框架核心组件类实例详解
Aug 06 #PHP
PHP使用Session实现上传进度功能详解
Aug 06 #PHP
PHP使用ajax的post方式下载excel文件简单示例
Aug 06 #PHP
PHP中的自动加载操作实现方法详解
Aug 06 #PHP
Thinkphp自定义生成缩略图尺寸的方法
Aug 05 #PHP
You might like
PHP数据集构建JSON格式及新数组的方法
2012/11/07 PHP
php利用腾讯ip分享计划获取地理位置示例分享
2014/01/20 PHP
phpcms中的评论样式修改方法
2016/10/21 PHP
jquery text,radio,checkbox,select操作实现代码
2009/07/09 Javascript
js计算页面刷新的次数
2009/07/20 Javascript
javascript 文章截取部分无损html显示实现代码
2010/05/04 Javascript
EXTJS FORM HIDDEN TEXTFIELD 赋值 使用value不好用的问题
2011/04/16 Javascript
如何用JavaScript动态呼叫函数(两种方式)
2013/05/03 Javascript
JavaScript中的eval()函数使用介绍
2014/12/31 Javascript
jQuery中removeAttr()方法用法实例
2015/01/05 Javascript
js实现可控制左右方向的无缝滚动效果
2016/05/29 Javascript
BootStrap+Angularjs+NgDialog实现模式对话框
2016/08/24 Javascript
jQuery中animate的几种用法与注意事项
2016/12/12 Javascript
javascript基本数据类型及类型检测常用方法小结
2016/12/14 Javascript
jQuery获取选中单选按钮radio的值
2016/12/27 Javascript
微信小程序之页面跳转和参数传递的实现
2017/09/29 Javascript
详解vue-cli+es6引入es5写的js(两种方法)
2019/04/19 Javascript
基于mpvue的简单弹窗组件mptoast使用详解
2019/08/02 Javascript
Vue 动态路由的实现及 Springsecurity 按钮级别的权限控制
2019/09/05 Javascript
JS如何实现在弹出窗口中加载页面
2020/12/03 Javascript
python 简易计算器程序,代码就几行
2009/08/29 Python
Python删除空文件和空文件夹的方法
2015/07/14 Python
小议Python中自定义函数的可变参数的使用及注意点
2016/06/21 Python
Python中按键来获取指定的值
2019/03/02 Python
Python常见数字运算操作实例小结
2019/03/22 Python
Python文件操作函数用法实例详解
2019/12/24 Python
浅谈Python访问MySQL的正确姿势
2020/01/07 Python
python 30行代码实现蚂蚁森林自动偷能量
2021/02/08 Python
eBay比利时购物网站:eBay.be
2019/08/09 全球购物
科颜氏英国官网:Kiehl’s英国
2019/11/20 全球购物
教师师德教育的自我评价
2013/10/31 职场文书
自主招生推荐信范文
2014/05/10 职场文书
药品开票员岗位职责
2015/04/15 职场文书
linux下安装redis图文详细步骤
2021/12/04 Redis
vue2的 router在使用过程中遇到的一些问题
2022/04/13 Vue.js
Win11无法安装更新补丁KB3045316怎么办 附KB3045316补丁修复教程
2022/08/14 数码科技