str怎么把最后一个字符去掉(因str_replace导致的注入问题总结)
str怎么把最后一个字符去掉
因str_replace导致的注入问题总结研究了下replace的注入安全问题。
一般sql注入的过滤方式就是引用addslashes函数进行过滤。
他会把注入的单引号转换成\',把双引号转换成\",反斜杠会转换成\\等
写一段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函数的:
一个单引号或者双引号直接被转义,字符串注入到这里基本上gg了。没戏了。
addslashes的问题:
addslashes会把%00转换成\0
addslashes会把单引号(')转换成\'
因为使用了str_replace函数,会替换那么输入%00' 就被addslashes函数自动添加\0\',然后我们匹配0,就变成了\\'再次转换成\',单引号成功逃逸。
|
<?php echo str_replace ( "0" , "" , "\0\'" ) ?> |
\0\'就是我们输入的%00'
会输出:
那么知道了原理根据上面的php代码构造合适的sql语句绕过addslashes过滤
单引号成功逃逸,这里不能用单引号闭合了,后门闭合会被过滤那么直接:
返回真:
返回假
那么想出数据就很方便。这里不演示了常规语句就行了。
模拟环境没啥意思,去网上找了个别人的代码审计文章,找到了一个雨牛挖的cmseasy的str_replace绕过注入的真实案例
2014年的漏洞,cmseasy相关版本网上已经找不到了,我改写了个cmseasy,方便测试这个replace注入:
cmseasy环境下载:链接: https://pan.baidu.com/s/1kghapxub3ui36fyx4ibw9w 提取码: 7aj3
存在问题的目录lib/plugins/pay/alipay.php
第87行用了str_replace替换
替换后的内容赋值给了$order_sn
往下看发现调用了check_money函数,跟踪下这个函数查看内部实现:
uploads/lib/table/pay.php
先是赋值然后调用了getrow函数,跟进去看看:
uploads/lib/inc/table.php
condition没有啥数据库操作后跟下面那个函数,跟踪下rec_select_one:
还在table.php文件下:
跟下sql_select函数:
被带入数据库查询:
默认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注入
那么修复方案是什么呢?
回到刚开始的alipay.php
第79行
正则匹配下\'
然后再次访问:
直接跳转了不再停留了。
修复方案:
|
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
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对开心学习网的支持。
原文链接:https://www.cnblogs.com/piaomiaohongchen/p/11304582.html
- str怎么把最后一个字符去掉(因str_replace导致的注入问题总结)
- thinkphp框架案例(thinkphp5.1框架容器与依赖注入实例分析)
- 简单的sql注入举例(分享一个简单的sql注入)
- php各种绕过姿势(php面试实现反射注入的详细方法)
- 常见的sql注入技术(浅谈一次与sql注入 & webshell 的美丽“邂逅”)
- laravel接口请求模拟(Laravel 类和接口注入相关的代码)
- pythonsql注入检测(Python版Mssql爆破小脚本)
- sql注入原理详细(Sql注入原理简介_动力节点Java学院整理)
- php提供哪些函数来避免sql的注入(PHP与SQL语句写一句话木马总结)
- php依赖注入和控制反转的区别(php反射学习之依赖注入示例)
- php防sql注入(万能密码的SQL注入漏洞其PHP环境搭建及防御手段)
- php全栈之路教程(PHP进阶学习之依赖注入与Ioc容器详解)
- sql注入防范有哪些方法(如何有效防止sql注入的方法)
- pyqt5加载chrome浏览器(PyQt5内嵌浏览器注入JavaScript脚本实现自动化操作的代码实例)
- python sql注入怎么避免(Python实现SQL注入检测插件实例代码)
- 如何使用HttpModule实现sql防注入
- 各地出招烘 热 旅游(各地出招烘热旅游)
- 2021款起亚霸锐到店了 更换车标,竞争宝马X5有戏吗(2021款起亚霸锐到店了)
- 新款起亚霸锐实拍,比普拉多气派,配3.0T V6,引入国内或许能大卖(新款起亚霸锐实拍)
- ()
- 张勇 阿里新任掌门人(阿里新任掌门人)
- 毛戈平全国第一柜花落银泰 高端国货迎来 高光 时刻(毛戈平全国第一柜花落银泰)
热门推荐
- mysql8.0.21的安装步骤(mysql8.0.23 msi安装超详细教程)
- 怎么用织梦上传源码(如何把织梦dedecms数据生成json)
- 微信小程序图片加特效(微信小程序实现可实时改变转速的css3旋转动画实例代码)
- showModalDialog在谷歌浏览器下获取不到返回值
- js数组去重的十种方法(JavaScript常用数组去重实战源码)
- sql版本号处理并发(SQL server高并发生成唯一订单号的方法实现)
- python二叉树是怎么来的(Python二叉树的镜像转换实现方法示例)
- sqlserver字符串判断函数(解决sql server保存对象字符串转换成uniqueidentifier失败的问题)
- vue使用elementui框架(总结Vue Element UI使用中遇到的问题)
- 如何查看mysql慢查询日志(MySQL慢查询如何定位详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9