当前位置:Gxlcms > 数据库问题 > 那些年我们一起挖掘SQL注入 - 6.全局防护Bypass之一些函数的错误使用

那些年我们一起挖掘SQL注入 - 6.全局防护Bypass之一些函数的错误使用

时间:2021-07-01 10:21:17 帮助过:29人阅读

 

浏览器输入”http://localhost/sqltest/streplace.php?id=1‘&title=news title”,发现报错了,我们直接打印出执行的sql语句如下图:
技术分享
发现参数id右边的单引号被反斜杠转义成字符了,说明又可以注入了。
简单分析下上面id参数的执行过程,-1’经过addslashes函数转义后变成了-1\’,然后再经过str_replace函数干掉了单引号变成了-1\,最后带入查询的语句才是下面这样:

SELECT * FROM news WHERE id=‘1\‘ and title=‘news title‘

反斜杠转义了sql查询语句里id后面那个单引号,导致title参数可以构造sql注入语句了,我们直接构造获取管理员账户密码的语句”http://localhost/sqltest/streplace.php?id=-1‘&title=union select 1,2,concat(name,0x23,pass) from admin%23”
技术分享
第二种情况是str_replace函数是用户可控的,就是说用户想把啥替换成空就可以将什么替换为空。
首先我们先看看addslashes函数对%00-%ff的转义情况,经过fuzz发现%00会被转义为\0,如下:
技术分享
那么注入的时候我们提交%00’,经过addlashes就会变为\0\’,这时候我们用replace函数替换0为空就变成了\‘,成功转义了转义字符让单引号逃逸出来,从而造成注入漏洞。

stripslashes函数的错误使用

这个函数的定义是删除由 addslashes() 函数添加的反斜杠,所以很明显使用不当的话就会引发SQL注入。缺陷代码如下:

<?php
require_once(‘common.php‘);
$conn = mysql_connect(‘localhost‘, ‘root‘, ‘braid‘) or die(‘bad!‘);
mysql_query("SET NAMES binary‘");
mysql_select_db(‘test‘, $conn) OR emMsg("数据库连接失败");
$tmp_id = isset($_GET[‘id‘]) ? $_GET[‘id‘] : 1;
$id = stripslashes($tmp_id);
$sql = "SELECT * FROM news WHERE id=‘{$id}‘";
echo $sql.‘<br />‘;
$result = mysql_query($sql, $conn) or die(mysql_error());
?>

 

浏览器输入”http://localhost/sqltest/stripslashes.php?id=-1‘",发现报错了,echo出执行的sql语句如下图:
技术分享
分析下参数id的执行过程,-1’经过addslashes函数转义后变成了-1\’,然后再经过stripslashes函数干掉了反斜杠变成了-1’,所以又可以愉快的注入了。
获取管理员账户密码的语句”http://localhost/sqltest/stripslashes.php?id=-1‘ union select 1,2,concat(name,0x23,pass) from admin%23”
技术分享

那些年我们一起挖掘SQL注入 - 6.全局防护Bypass之一些函数的错误使用

标签:img   引号   target   word   注入   过程   fan   mon   get   

人气教程排行