攻防世界(16):warmup
摘要:
第一道FUZZ 模糊测试(Fuzzing),是一种通过向目标系统提供非预期的输入并监视异常结果来发现软件漏洞的方法 没给附件,先看一下nc出来是什么 给了一个地址,应该是可以在这个地址栈溢出,由于不知道是32位的还是64位的,疯狂nc爆破就行 #exp注释一下 #!/usr/bin/env pyth
攻防世界(15):Mary_Morton
摘要:
查壳 ida中很明显告诉我们有栈溢出漏洞和字符串漏洞,有后门 先用格式化字符串泄露偏移去找到canary 偏移为6,看看作为canary的v2离buf有多远 0x90-0x8=0x88,0x88=136,136/8=17,17+偏移6=23,泄露第23个地址的值就行 计算栈溢出 buf的88+can
攻防世界(14):forgot
摘要:
查壳,没开栈保护和NX 这个题目的ida变量有点多,慢慢读 fgets没啥漏洞,原来漏洞在scanf这里 然后查找有没有system函数,没有需要利用第一个fgets写,但这里还是有的,把v3改成我们需要的函数名即可 #exp #!/usr/bin/env python from pwn impor
攻防世界(13):dice_game
摘要:
查壳 看ida,和guess_number那题一样有seed,并且一样是猜数字连续猜中得到flag,看看能不能覆盖把seed改成我们想要的 read是50,但栈中seed在10的位置,可以直接通过buf覆盖到seed 编写exp #!/usr/bin/env python from pwn impo
攻防世界(12):实时数据检测
摘要:
查壳。。。什么都没开 看ida s开的208,fgets却是512,明显用%p泄露格式化字符串地址的偏移,然后覆盖key就行 偏移为12 但是覆盖key的时候容易发现,key要求的的数为35795746,转换为十六进制是0x2223322,单纯用%index$n是不行的,要将key要求的数转换成十六
攻防世界(11):string
摘要:
查壳:开了Canary和NX,没开Pie ida查看每个函数的有用的意义(a1==v4) 函数 意义 main 引导进入sub_400D72 sub_400D72 获取输入,长度<12继续 sub_400A7D 获取输入,直到输入为 east 为止才能进行下一个流程 sub_400BB9 获取输入,
攻防世界(10):get_shell
摘要:
查壳,只开了NX,可以去拿shell 看ida,的确找不到system有关的函数,但发现了read的漏洞(read开的大小为100,比buf大),只能去拿附件中的另一个文件下手,这是一个运行库文件通过它来获得两者的地址 使用 pwntools,获得 write 和 system 的相对位置,0x99
攻防世界(9):level2
摘要:
查壳,只开了NX,可以利用栈溢出 level0是直接覆盖到运行system('/bin/sh')的函数,level2是先覆盖到call system的地址,然后覆盖/bin/sh 注意,如果覆盖的是system的地址,则要加上四位覆盖call之后的eip压栈,运行gdb可以看到eip压栈 shift
攻防世界(8):level0
摘要:
查壳,只开了NX,可以利用栈溢出 ida中的callsystem函数调用了/bin/sh 这题练习一下elf调用函数地址写exp #!/usr/bin/env python from pwn import * p = remote('111.200.241.244',35917) elf = ELF