SQL注入——类型及提交方法
SQL注入——类型及提交方法
1.前言
在现实的SQL注入安全测试中,我们首先要明确提交数据及提交方法后再进行相关的注入,其中提交数据类型和提交方法可以通过抓包分析获取,后续的安全测试中我们也必须满足同等的操作才能进行注入。
data:image/s3,"s3://crabby-images/34500/345005d917016235f27b55ea06b171b032cd861d" alt=""
2.数据类型
- 数字型语句:
1 |
|
- 字符型语句:
1 |
|
- 搜索型语句:(like)
1 |
|
通过三种语句的对比可以看见,在字符型语句中变量是需要使用到引号的,而在搜索类型中则需要注释单引号’、百分号%、括号等,这个需要自己进行多次尝试,搜索语句的类型并不多。因此我们的参数值在注入的时候需要去注意类型的判别。
json类型:
3.请求方法
不同的请求方式,上传的数据类型和大小是有区别的。我们不在上传的时候要根据请求的发送进行提交相关的语句,因此同的请求方法可能会有着不同注入的写法和方式。
1 |
|
(注:在java、python等语言的框架中基本也是一样的思路,只是写法可能会有细微的出入)
我们尝试发送数据http://127.0.0.1/liaoyue.php/?g=123&p=456
data:image/s3,"s3://crabby-images/72e4f/72e4f6e824971f05ebfea41ac60cd2a4a7d6be3c" alt=""
data:image/s3,"s3://crabby-images/b9eea/b9eeaa4a0534820dc8263b7b125574e61e835133" alt="3"
接下来修改传送方法,通过火狐插件 HackBar 在post提交p。
data:image/s3,"s3://crabby-images/e92f7/e92f7cff191936eb79576341ce8d1c49c24cc954" alt=""
data:image/s3,"s3://crabby-images/b696d/b696d95de889969477bac5a71a6d3c59352890c3" alt=""
最终效果:
data:image/s3,"s3://crabby-images/c8d66/c8d669867d22ef65405e3da0b178206ce73adfc2" alt=""
data:image/s3,"s3://crabby-images/e92f7/e92f7cff191936eb79576341ce8d1c49c24cc954" alt=""
这也就是说我们注入的位置是有要求和限制的,不同的请求方式会导致我们注入位置形成影响
首先明确cookie并不是请求方法,是在数据包中cookie可以通过修改数据包中的cookie进行注入
data:image/s3,"s3://crabby-images/984bd/984bd7793468f8776ecd7e752a5c42f9638795b8" alt=""
既可以通过GET请求,也可以通过POST请求,基本可以说可以REQUST能在所有方法的位置提交。
data:image/s3,"s3://crabby-images/212d2/212d223694dfe4164c3402ba882d8a786bc9e064" alt=""
当然,在post请求的方法中也只是将位置接在post传输的数据后面,其他没有区别。
1 |
|
测试网址:http://ip.tool.chinaz.com/
data:image/s3,"s3://crabby-images/ac4d6/ac4d6ea06cbf9f9367c9215d19c22f01d36d78c4" alt=""
data:image/s3,"s3://crabby-images/10367/10367c916ba53961f633434b0f42212285ba7606" alt=""
SQL注入——类型及提交方法
https://one-null-pointer.github.io/2022/08/05/SQL注入——类型及提交方法/