sqli笔记-基于错误的SQL注入与WAF绕过

简介: 正文测试的是登陆功能,此功能会向数据库发送查询的请求,这里我们仔细来看一下,获取我的数据并通过 POST 请求发送。工具使用的是Burp Suite,这里拦截了请求并将其发送到repeater:


正文


测试的是登陆功能,此功能会向数据库发送查询的请求,这里我们仔细来看一下,获取我的数据并通过 POST 请求发送。

工具使用的是Burp Suite,这里拦截了请求并将其发送到repeater:
19.png

作为 SQL 查询的常规方法,首先需要使用单引号或双引号来进行测试:

email=qaramany'

20.png

查看响应,在第 4173 行收到此错误,因此我只是搜索此错误以获取有关与之交互的数据库的更多信息。

直接google搜索一下 error No.: 2147217900这个错误就会知道:

21.png

发现使用的是 MS-SQL 数据库进行了基于错误的 SQL 注入,比较麻烦的是暂时没找到任何漏洞利用;

因为这里针对“select”或“order by”等关键字有过滤,这意味着“+select”可能被过滤并返回 500  错误,这是经过50多次的重放,才弄清楚的WAF 逻辑;

所以不能注入一个" select "或" order by "或" group by " 或任何可选的基于错误的攻击向量,当你注入包含上述表达式的查询的时候通常被WAF拦截。

使用%2b字符连接字符串作为bypass。%2B+的编码

因此,将它与特定函数调用的结果一起使用,这些函数调用会触发对所需数据的数据类型转换错误。

我们现在可以通过一些函数绕过。

类似下面的:

  • SUSER_NAME()
  • USER_NAME()
  • PERMISSIONS()
  • DB_NAME()
  • FILE_NAME()
  • TYPE_NAME()
  • COL_NAME()

payload如下:

qaramany'%2buser_name(@@version)

这个payload可以查出数据库的版本

  • qaramany: 这是我的名字
  • ':触发错误的单引号
  • %2b:是+的编码
  • User_name():在寻找的数据上触发数据类型转换错误的函数调用

22.png

有时我们会得到500错误,所以基于相同的方法创建有效载荷

qaramany'%2buser_name(convert(int,(SYSTEM_USER)))--

这绕过了获取SYSTEM_USER的WAF

一些poc如下:

qaramany’%2buser_name(convert(int,(SESSION_USER))) — 
qaramany’%2buser_name(UPPER(‘sql+tutorial+is+fun!’)) — 
qaramany’%2buser_name(IIF(5=4,+’YES’,+’HackedBy_c0nqr0r&0x4m’)) — 
qaramany’%2buser_name(convert(int,(db_name()))) —


总结

本文是针对 在注入" select "或" order by "或" group by " 或任何可选的基于错误的攻击向量的时候,被WAF拦截的时候的一些思路.

目录
相关文章
|
12天前
|
SQL 关系型数据库 MySQL
怎么通过第三方库实现标准库`database/sql`的驱动注入?
在Go语言中,数据库驱动通过注入`database/sql`标准库实现,允许统一接口操作不同数据库。本文聚焦于`github.com/go-sql-driver/mysql`如何实现MySQL驱动。`database/sql`提供通用接口和驱动注册机制,全局变量管理驱动注册,`Register`函数负责添加驱动,而MySQL驱动在`init`函数中注册自身。通过这个机制,开发者能以一致的方式处理多种数据库。
|
17天前
|
SQL 安全 关系型数据库
SQL 注入神器:SQLMap 简单使用
SQL 注入神器:SQLMap 简单使用
|
26天前
|
SQL 存储 Java
如何避免SQL注入攻击?
如何避免SQL注入攻击?
|
1月前
|
SQL 安全
jeecg-boot sql注入漏洞解决
jeecg-boot sql注入漏洞解决
108 0
|
1天前
|
SQL 安全 Java
Spring Boot中的跨站点脚本攻击(XSS)与SQL注入防护
【6月更文挑战第15天】在现代Web应用程序开发中,安全性是一个至关重要的课题。跨站点脚本攻击(XSS)和SQL注入是最常见的两种攻击类型,它们可以严重威胁到应用程序的安全。
6 0
|
13天前
|
SQL 监控 安全
sql注入取数据库
SQL注入是一种攻击技术,用于在SQL查询中注入恶意代码,从而绕过安全措施,获取、修改或删除数据库中的数据。这种行为是非法的,并且严重违反了网络安全和隐私原则。我不能提供关于如何进行SQL注入的指导或
|
15天前
|
SQL 数据库 关系型数据库
【SQL注入】 注入神器sqlmap的使用
数据库 SQL注入漏洞 sqlmap
51 2
|
17天前
|
SQL XML 安全
Pikachu SQL 注入通关解析
Pikachu SQL 注入通关解析
|
17天前
|
SQL 安全 关系型数据库
SQL注入常用姿势
该内容介绍了SQL注入攻击和防御的一些基本概念,以及MySQL中的几个函数:`MID()`用于提取文本字段的字符,`LIMIT()`用于限制查询结果的数量,`COUNT()`计算元组数量。它还详细讲解了两种SQL注入方法:基于布尔盲注和基于时间盲注,包括如何猜解数据库、表和字段信息。此外,还提到了SQL注入工具Sqlmap的使用方法和一些绕过过滤策略。
26 0
SQL注入常用姿势
|
17天前
|
SQL 机器学习/深度学习 人工智能
Web LLM 实验:利用 LLM API 实现 SQL 注入
Web LLM 实验:利用 LLM API 实现 SQL 注入