QCTF writeup

X-man-A face:
这道题是二维码补图的题,用ps将那两个空的角补全就好了,扫码可以得到一串base64加密的字符串,解码就是了
Flag:QCTF{Pretty_Sister_Who_Buys_Me_Lobster}

X-man-Keyword:
这道题给了一张png图片,常规思路试了一下,发现好像没什么东西藏在图片中,用Stegsolve发现图层没什么问题,也提取不出什么东西,长宽也没问题,想了想有没可能是lsb隐写,就去网上找了个工具,解了下 ,密码根据图片猜就是lovekfc

image.png

噢噢 发现有点东西PVSF{vVckHejqBOVX9C1c13GFfkHJrjIQeMwf}

这一看就应该是一个加密 ,试了一波凯撒 ,呃呃呃,然后就去google,百度,搜狗查了挺久的没什么发现,直到出题人给了hint2:种把关键词提前的置换
发现了一种关键词加密法的加密算法
原理 参考https://wenku.baidu.com/view/ab7a4f0131126edb6f1a10a0.html

最后根据原理写出解密脚本


image.png

NewsCenter:
简单的sql注入,用sqlmap跑就可以了


image.png

Lottery:
简单看了下题目,最终目标是买个flag,初始money是20, 买lottery需要的9990000,然后就是玩一个游戏--猜数字 ,数字猜对的越多,获得的money越多
查看了网页的js代码,找到关键逻辑

image.png

只要number数组全为true,就可以获得最多的money
抓了个包

image.png

发现了numbers数组
只要将数组的值全改为true,那么就可以一次赢最多的money

image.png

重复多几次就够money买flag了

image.png

Xman-dice_game:
拿到题目,看了下防护机制:

image.png

程序是64位的 只开启了NX
拖到IDA中反汇编一下

image.png

程序的逻辑也很简单,就是玩猜数字优秀,要连续猜中50次 ,就会将flag打印出来

利用思路:
将seed种子覆盖成一个固定的值,然后爆破处程序的随机数
Seed在栈中的偏移

image.png

输入70个1就可以将seed覆盖成一个常数
爆破脚本:

image.png
image.png

getshell脚本:

image.png
image.png

Xman-stack2:
防护进制

开启了NX和Canary 说明不是一般的栈溢出
用ida反汇编后 ,查看代码发现了两个漏洞点

image.png

主要是这个数组下标溢出 ,同时这个数组下标溢出可以使得打印数组的循环输出256个栈上的字符,只要将v13[-20] = -1

image.png
image.png

根据打印出来的内容可以得到栈上ebp和返回地址对应数组的偏移,然后通过修改功能就可以一个字节一个字节的修改返回地址,构造ropchain了
因为程序中本来就有system函数,所以我将返回地址修改成hackhere函数的地址,但是打远程时 ,服务器上不能用/bin/bash getshell
所以想到泄露libc地址,利用puts函数打印处printf_got地址的内容

image.png

泄露出来后在libc database search那个网站查到相应的libc版本
这里查到两个 ,试了后发现是libc6-i386_2.23-0ubuntu10_amd64
我查到libc版本后,用one_gadget 来找gadget

image.png

还有一点是泄露完地址返回main函数后栈的地址会发生变化,所以要重新算,将数组再打印一遍就好了

exp:

image.png
image.png

NoLeak:
这道题我比赛的时候没有做出来,那时候傻傻的unlink修改了存储chunk指针的数组的内容后就不知道怎么做了,比赛结束以后看writeup才明白怎么做
先分析下程序:
程序的漏洞有两个,一个是UAF,另一个是堆溢出

image.png
image.png

具体思路:
因为程序没开NX和PIE,所以可以通过向bss段写shellcode,然后执行的方式来getshell,因为没有办法直接控制rip,所以通过向__malloc_hook写入shellcode的地址,然后再malloc一个chunk,触发malloc_hook来getshell。至于要怎么写,可以通过fastbins dup 获取包含 数组buf的chunk, 修改buf数组的内容,将__malloc_hook的地址写到数组中,然后再通过编辑功能向__malloc_hook写入shellcode的地址

具体步骤:

  1. 先生成大小分别为0x70,0x90,0x90的3个chunk0,1,2
  2. 利用unsorted bin attack ,向0x601040+0x28 + 0x10的地址写入 main_arena+0x88的地址,
  3. 通过fastbins dup,在数组buf上分配堆块。这是为了后面修改buf数组的内容做准备 ,将chunk0 free掉,然后修改chunk0的fd指针,使其指向 0x601075,因为经过unsorted bin attack后,0x601075+0x8处的值为0x7f,大小符合fastbins list。先生成一个0x70大小的chunk,然后再生成一个0x70大小的chunk,就在0x601075那分配出一个chunk,同时将buf[9]地址的内容修改为0x601070 ,即向buf[9]写入指向buf[6]的指针
  4. 用编辑功能,将&buf[6]地址上的内容,将buf[6]修改为0x601090,为后面向bss段写shellcode做准备,同时partial overwrite 修改buf[7]的最低位,使其变成__malloc_hook的地址
  5. 用编辑功能 ,修改buf[7],使__malloc_hook 指向0x601090
  6. 向0x601090 即*buf[6] ,写入shellcode
  7. 随便分配一个堆,触发__malloc_hook getshell

下面画一张 buf的内存分布的示意图:

image.png

  • unsorted bin attack 向buf数组写入main_arena + 0x88的地址
update(1,p64(0x601040+0x28)*2)#unsorted bin attack 
print "update chunk1 fd and bk to [%s]"%"0x601040 + 0x28"
delete(0)
create(0x80,'G'*0x30)
image.png
  • fastbins dup 在buf数组的上分配chunk
update(0,p64(0x601075))
create(0x68,'H'*0x10)
create(0x68,'I'*3+p64(0x601070))#9

image.png
image.png

可以看到此时buf[9]地址的内容被修改为0x601070

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

推荐阅读更多精彩内容

  • 0x00 前言 Pwn弱鸡,比赛划水,只好跟着大佬的博客刷刷一些题目才能维持尊严,在刷题目的时候又发现了一些新姿势...
    Fish_o0O阅读 1,536评论 0 6
  • 记录一下,防止以后忘了 house_of_roman:该技术用于 bypass ALSR,利用12-bit 的爆破...
    zs0zrc阅读 1,704评论 1 0
  • pwntools简单语法 作为最好用的pwn工具,简单记一下用法: 连接:本地process()、远程remote...
    SueLyon阅读 24,242评论 3 38
  • 古时候重农轻商,商人没有地位,结果呢?吕不韦以商入仕,一路高歌。 十年前淘宝刚出现的时候被传为诈骗,结果呢?马云成...
    偏爱阅读 455评论 0 1
  • 2016年3月22日 星期二 雨 去开学的第一天就下起绵绵细雨,熟悉的街道,熟悉的早餐路边摊,熟悉的校大门卖炒粉的...
    贰伍阅读 273评论 0 0