SQL注入绕过详解和防护

本文详细介绍了SQL注入的多种绕过技术,包括大小写、注释、双写、等价关键字、空格替代、去除关键字过滤的绕过方法。同时,通过实例展示了如何在不同场景下利用这些技巧进行SQL注入。此外,文章还讨论了MySQL的宽字节注入和Base64编码绕过,并提到了二阶注入问题。最后,提出了防御SQL注入的策略,如检查数据类型、过滤特殊符号和使用预编译语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、 SQL 注入的绕过技术

1、 大小写绕过

如果过滤器通过关键字进行过滤并没有识别大小写 ,我们就可以使用大小写来进行绕过,因为 SQL 语句是不区分大小写的。

原始语句

SELECT * FROM users WHERE id='1' LIMIT 0,1

大小写掺杂注入

SELECT * FROM users WHERE id='1'And 1=1--+' LIMIT 0,1

问题存在的原因是:过滤器过滤了正常的关键字,但是并没有对字符串进行处理。

2、 注释绕过

Less-23

打开sqli-labs靶机

[root@localhost ~]# cd /var/www/html/ #进入sqli-labs所在目录

[root@localhost html]# cat sqli-labs/Less-2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cwillchris

你的鼓励将让我产出更多优质干货

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值