亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 3881 | 回復(fù): 9
打印 上一主題 下一主題

溢出攻擊eip寄存器覆蓋問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2011-12-22 19:52 |只看該作者 |倒序?yàn)g覽
     在自己的電腦上演示溢出攻.出現(xiàn)如下問題:
         gdb中測試覆蓋eip。當(dāng)輸入的n個‘A’時可以eip顯示為414141,差一個字節(jié)沒覆蓋。但當(dāng)輸入n+1個'A'時確顯示是eip內(nèi)容為函數(shù)調(diào)用返回ret語句地址的內(nèi)容。
         求解~~~

論壇徽章:
11
未羊
日期:2013-12-16 12:45:4615-16賽季CBA聯(lián)賽之青島
日期:2016-04-11 19:17:4715-16賽季CBA聯(lián)賽之廣夏
日期:2016-04-06 16:34:012015亞冠之卡爾希納薩夫
日期:2015-11-10 10:04:522015亞冠之大阪鋼巴
日期:2015-07-30 18:29:402015亞冠之城南
日期:2015-06-15 17:56:392015亞冠之卡爾希納薩夫
日期:2015-05-15 15:19:272015亞冠之山東魯能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16賽季CBA聯(lián)賽之八一
日期:2016-07-22 09:41:40
2 [報告]
發(fā)表于 2011-12-22 20:06 |只看該作者
分別啥時候 p $eip 的?

論壇徽章:
0
3 [報告]
發(fā)表于 2011-12-22 20:14 |只看該作者
在gdb中i reg得到的eip的內(nèi)容。是發(fā)生段錯誤后返回后的

論壇徽章:
0
4 [報告]
發(fā)表于 2011-12-22 20:16 |只看該作者
是在gdb中調(diào)試出錯返回后i reg得到的eip信息

論壇徽章:
11
未羊
日期:2013-12-16 12:45:4615-16賽季CBA聯(lián)賽之青島
日期:2016-04-11 19:17:4715-16賽季CBA聯(lián)賽之廣夏
日期:2016-04-06 16:34:012015亞冠之卡爾希納薩夫
日期:2015-11-10 10:04:522015亞冠之大阪鋼巴
日期:2015-07-30 18:29:402015亞冠之城南
日期:2015-06-15 17:56:392015亞冠之卡爾希納薩夫
日期:2015-05-15 15:19:272015亞冠之山東魯能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16賽季CBA聯(lián)賽之八一
日期:2016-07-22 09:41:40
5 [報告]
發(fā)表于 2011-12-22 20:37 |只看該作者
第二次既然是正確的返回地址怎么會出錯?

論壇徽章:
0
6 [報告]
發(fā)表于 2011-12-22 20:52 |只看該作者
所以我也很不解。這個是打印結(jié)果:
Program received signal SIGSEGV, Segmentation fault.
0x08048434 in main ()
(gdb) i reg
eax            0x0        0
ecx            0xbffff2a8        -1073745240
edx            0x28d360        2675552
ebx            0x28bff4        2670580
esp            0xbffff2ec        0xbffff2ec
ebp            0x41414141        0x41414141
esi            0x0        0
edi            0x0        0
eip            0x8048434        0x8048434 <main+64>
eflags         0x10296        [ PF AF SF IF RF ]
我disas main得到的是<main+64>是ret。
如果是第一種情況時結(jié)果會是 0x414141 in ?();

論壇徽章:
11
未羊
日期:2013-12-16 12:45:4615-16賽季CBA聯(lián)賽之青島
日期:2016-04-11 19:17:4715-16賽季CBA聯(lián)賽之廣夏
日期:2016-04-06 16:34:012015亞冠之卡爾希納薩夫
日期:2015-11-10 10:04:522015亞冠之大阪鋼巴
日期:2015-07-30 18:29:402015亞冠之城南
日期:2015-06-15 17:56:392015亞冠之卡爾希納薩夫
日期:2015-05-15 15:19:272015亞冠之山東魯能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16賽季CBA聯(lián)賽之八一
日期:2016-07-22 09:41:40
7 [報告]
發(fā)表于 2011-12-22 21:01 |只看該作者
本帖最后由 zylthinking 于 2011-12-22 21:02 編輯

這我也沒辦法解釋了, 我倒知道有個棧破壞檢測的東西, 但似乎也解釋不通。
但看那個ret, 很顯然是main 中 return 生成的; 倒不是 call 時那個返回地址

論壇徽章:
0
8 [報告]
發(fā)表于 2011-12-22 21:07 |只看該作者
#include <stdio.h>
#include <string.h>
額~看來要擱淺了。
不過有另外發(fā)現(xiàn)就是如果arr的長度定義為5時就只是顯示段錯誤。但如果長度是10的話還會調(diào)出** stack smashing detected ***顯示錯誤。
int main(int argc, char **argv)
{
        char arr[5];

        strcpy(arr, argv[1]);
        printf("arr: 0x%c\n", *arr);

        return(0);
}

論壇徽章:
11
未羊
日期:2013-12-16 12:45:4615-16賽季CBA聯(lián)賽之青島
日期:2016-04-11 19:17:4715-16賽季CBA聯(lián)賽之廣夏
日期:2016-04-06 16:34:012015亞冠之卡爾希納薩夫
日期:2015-11-10 10:04:522015亞冠之大阪鋼巴
日期:2015-07-30 18:29:402015亞冠之城南
日期:2015-06-15 17:56:392015亞冠之卡爾希納薩夫
日期:2015-05-15 15:19:272015亞冠之山東魯能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16賽季CBA聯(lián)賽之八一
日期:2016-07-22 09:41:40
9 [報告]
發(fā)表于 2011-12-22 22:14 |只看該作者
反匯編一下, 然后一步步跟, 總能得到解釋的

論壇徽章:
0
10 [報告]
發(fā)表于 2011-12-24 00:53 |只看該作者
lz,您可以看看這
http://sunus.is-programmer.com/
我這個blog廢棄之前最后一篇就是寫個緩沖區(qū)溢出小實(shí)驗(yàn)。
gcc是有棧檢測的東西,你或許編譯的時候需要加參數(shù)取消棧檢測之后再進(jìn)行實(shí)驗(yàn)
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP