青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

由段錯誤引申出的緩沖區溢出攻擊分析

    前段時間在寫《段錯誤造成的常見詭異宕機情況總結(中)》時,分析到 程序中數據寫超時有可能寫到this指針所在的地址里面,導致最終詭異的宕機。其實網絡攻防里常用的緩沖區溢出攻擊也是這個道理,除了使用戶程序甚至計算機掛掉外,還有可能執行攻擊者想執行的任何程序,這篇文章主要詳細剖析一下第二種攻擊的方法以及現在Linux(包括各種修改版本,例如Android)、Windows下常使用的防范措施。
   話不多說,先貼一則小例子:
   
  1  ** 
  2  *\author peakflys 
  3  *\email peakflys@gmail.com
  4  *\brief Buffer overflow attack 
  5  
*/
  6 #include <iostream>
  7 using namespace std;
  8 
  9 void hack()
 10 {
 11     cout<<"hacked"<<endl;
 12 }
 13 
 14 void test()
 15 {
 16     char a[4];
 17     int *ret = (int *)(a + 24);
 18     *ret -= 0x48;
 19 }
 20 
 21 int main()
 22 {
 23     test();
 24     return 0;
 25 }
運行結果:
     hacked
整個過程沒有顯示調用hack函數,而最終hack函數卻得以運行。下面給出三個函數的匯編代碼:
0000000000400814 <_Z4hackv>:
void hack()
{
  400814:   55                      push   %rbp
  400815:   48 89 e5              mov    %rsp,%rbp
  cout<<"hacked"<<endl;
  400818:   be b8 09 40 00     mov    $0x4009b8,%esi
  40081d:   bf 80 0d 60 00      mov    $0x600d80,%edi
  400822:   e8 c1 fe ff ff        callq  4006e8 <_ZStlsISt11char_traitsIcEERSt13basic_ostreamIcT_ES5_PKc@plt>
  400827:   be 08 07 40 00     mov    $0x400708,%esi
  40082c:   48 89 c7              mov    %rax,%rdi
  40082f:   e8 c4 fe ff ff         callq  4006f8 <_ZNSolsEPFRSoS_E@plt>
  400834:   c9                      leaveq 
  400835:   c3                      retq   
}

0000000000400836 <_Z4testv>:
void test()
{
  400836:   55                      push   %rbp
  400837:   48 89 e5              mov    %rsp,%rbp
  char a[4];
  int *ret = (int *)(a + 24);
  40083a:   48 8d 45 f0          lea    -0x10(%rbp),%rax
  40083e:   48 83 c0 18         add    $0x18,%rax
  400842:   48 89 45 f8          mov    %rax,-0x8(%rbp)
   *ret -= 0x48;
  400846:   48 8b 45 f8           mov    -0x8(%rbp),%rax
  40084a:   8b 00                   mov    (%rax),%eax
  40084c:   8d 50 b8               lea    -0x48(%rax),%edx
  40084f:   48 8b 45 f8            mov    -0x8(%rbp),%rax

  400853:   89 10                   mov    %edx,(%rax)
  400855:   c9                      leaveq
  400856:   c3                      retq
}

0000000000400857 <main>:

int main()
{
  400857:   55                      push   %rbp
  400858:   48 89 e5              mov    %rsp,%rbp
    test();
  40085b:   e8 d6 ff ff ff          callq  400836 <_Z4testv>
    return 0;
  400860:   b8 00 00 00 00      mov    $0x0,%eax
  400865:   c9                      leaveq
  400866:   c3                      retq
}
在調用test函數后,gdb打印結果:
(gdb) p $rsp
$1 = (void *) 0x7fffffffe2a0
(gdb) p $rbp
$2 = (void *) 0x7fffffffe2a0
(gdb) p /x *(0x7fffffffe2a8)
$3 = 0x400860
在test函數堆棧前面(如上,堆棧地址:0x7fffffffe2a8 )有函數返回的地址(即0x400860 )。test函數調用時的內存模型大致為:

   估計這時候大家都已經知道整個實現的詳細過程了,test函數中ret指針指向test函數返回地址0x7fffffffe2a8(注:這個很容易分析得到),然后通過函數偏移值0x48(注:這個根據特定平臺和特定編譯器來分析得出)來重定向返回值地址,即定向到hack函數,這段重定向代碼 也就是常說的shellcode。
   緩沖區溢出攻擊在平時的網絡攻擊中能占到50%的比例,上面test函數可以輕易的讓計算機崩潰,也可以輕易的執行任何病毒或者木馬程序。
   現在來分析一下防范措施。首先當然是作為程序員的我們需要注意的:寫數據時,特別警惕數據邊界,嚴防存在數據寫溢出的情況,類似于strcpy等函數不要使用或者小心使用。其次當然是通過其他方式的防范,上面我也提到了,shellcode中有兩個值是需要計算的,第一個是函數返回值地址,這個比較容易分析出來,因為編譯器是有固定的入棧壓棧規則的;第二個是兩個函數之間的偏移地址,函數地址在編譯階段就已經在代碼段固定下來了,偏移 只需要根據反匯編出的片段地址猜解出來(如果能完全反匯編出來,就不用猜了……)。這兩個值只要增加任何一個的計算難度,都可以有效減少這種漏洞的攻擊。目前Linux (包括各種修改版本,例如Android) 、FreeBSD、Windows 等主流操作系統都已采用 ASLR(Address space layout randomization)技術(iOS系統自iOS 4.3以后也支持了ASLR技術 ),這種技術就是通過對堆、棧、共享庫映射等線性區布局的隨機化來達到增加猜解出函數偏移的目的。當然這種技術僅僅是減少而非杜絕緩沖區溢出攻擊。
世界上沒有完美的程序,只有暫時想不到的bug                                                  by peakflys

posted on 2012-10-24 16:51 peakflys 閱讀(2547) 評論(2)  編輯 收藏 引用 所屬分類: C++服務器

評論

# re: 由段錯誤引申出的緩沖區溢出攻擊分析 2012-10-25 10:30 zuhd

樓主這個例子很不錯,但是有幾點沒講清楚哈,主要是以下兩句話
int *ret = (int *)(a + 24);
*ret -= 0x48;
我補充一下,班門弄斧了。
int *ret = (int *)(a + 24);
這句話的意思是取棧中的一個值,這個值其實就是call test之后下一條指令的地址偏移,也就是eip。為什么是24呢,首先char a[4]會被編譯器優化擴展成int,這是4*4=16,然后是test內部的push ebp4個字節,然后是push eip的4個字節,一共24個。拿到這個地址后,修改里面的內容即可。為什么是0x48呢,因為這個時候,真正的eip值是0x40085b,減去0x48=0x400818,也就是hack中的cout部分了。
  回復  更多評論   

# re: 由段錯誤引申出的緩沖區溢出攻擊分析 2012-10-25 10:44 peakflys

24那個值看一下匯編 或者 info frame 看一下堆棧幀也可以看出來 但是你計算的不對,上面的編譯環境使用的寄存器是rbp、rsp、rip(從上面匯編也可以看出來) 這些都是64位的,24的具體計算過程是這樣的:a數據擴展成4個int是16個字節,然后加上test函數調用時壓進堆棧的rbp 8個字節,總共是24個字節,這個位置就是調用test函數后的返回地址,修改內容即可,具體可以用gdb調試看一下 @zuhd
  回復  更多評論   

<2016年3月>
282912345
6789101112
13141516171819
20212223242526
272829303112
3456789

導航

統計

公告

人不淡定的時候,就愛表現出來,敲代碼如此,偶爾的靈感亦如此……

常用鏈接

留言簿(4)

隨筆分類

隨筆檔案

文章檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一本久道久久久| 欧美有码在线视频| 欧美精品一区二区三区久久久竹菊 | 国产精品蜜臀在线观看| 一区二区三区免费在线观看| 日韩午夜在线视频| 国产精品久久福利| 欧美与黑人午夜性猛交久久久| 午夜精品久久久久久久男人的天堂| 国产精自产拍久久久久久蜜| 久久久精品日韩欧美| 久久永久免费| 国产精品99久久久久久www| 国产精品99久久久久久www| 国产香蕉久久精品综合网| 欧美成人资源网| 欧美三级乱人伦电影| 久久国产精彩视频| 久久综合影视| 亚洲欧美自拍偷拍| 久久久久久9| 夜夜爽www精品| 小处雏高清一区二区三区| 极品尤物av久久免费看 | 性欧美激情精品| 久久亚洲综合| 午夜国产精品视频| 噜噜噜在线观看免费视频日韩| 亚洲一区二区三区四区视频| 欧美一区二区在线看| 夜夜嗨av一区二区三区四季av| 亚洲欧美日韩视频一区| 亚洲精品国久久99热| 亚洲一区亚洲| 一本大道久久精品懂色aⅴ| 亚洲欧美中文字幕| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲日本免费| 香蕉久久夜色精品国产| 夜夜嗨av一区二区三区免费区| 性久久久久久久久久久久| 99国产成+人+综合+亚洲欧美| 欧美在线一区二区| 亚洲欧美日韩中文播放| 麻豆freexxxx性91精品| 欧美一区二区免费观在线| 欧美日韩精品二区| 欧美激情精品久久久久久大尺度 | 亚洲乱码国产乱码精品精可以看| 亚洲欧美日韩一区二区三区在线观看| 亚洲精品国产视频| 久久久久久日产精品| 久久av二区| 国产精品免费看片| 夜夜躁日日躁狠狠久久88av| 亚洲三级网站| 免费试看一区| 欧美黄色大片网站| 亚洲国产精品成人va在线观看| 欧美一区二区黄| 午夜欧美精品| 国产精品久久久亚洲一区 | 亚洲愉拍自拍另类高清精品| 一本久久a久久精品亚洲| 欧美国产第二页| 91久久黄色| 亚洲精品少妇| 欧美aⅴ一区二区三区视频| 欧美国产日韩在线| 91久久综合亚洲鲁鲁五月天| 蜜臀av性久久久久蜜臀aⅴ四虎 | 嫩草影视亚洲| 亚洲高清二区| 久热精品视频在线观看一区| 欧美电影电视剧在线观看| 亚洲精品黄网在线观看| 欧美黄色aa电影| 一本色道久久综合精品竹菊| 亚洲一级在线| 国产女人精品视频| 久久久精品国产免大香伊| 美女成人午夜| 一本一本a久久| 国产精品久久久久久久久借妻 | 久久亚洲视频| 欧美激情第8页| 亚洲天堂网站在线观看视频| 国产精品视频大全| 久久久久久久久久久久久女国产乱 | 在线欧美小视频| 欧美电影在线| 亚洲深夜激情| 久久久久久网站| 日韩视频永久免费| 国产精品久久久久久久久免费樱桃| 午夜精品www| 亚洲二区在线| 欧美在线视频在线播放完整版免费观看| 国内揄拍国内精品久久| 欧美激情一区二区三级高清视频| 在线中文字幕不卡| 欧美va天堂| 午夜精品美女自拍福到在线| 在线观看欧美日本| 欧美日韩亚洲91| 久久国产精彩视频| 亚洲片在线资源| 久久香蕉国产线看观看网| avtt综合网| 一区二区三区在线免费观看| 欧美视频免费看| 麻豆久久婷婷| 欧美一区二区黄| 一本色道久久综合亚洲精品不卡| 蜜月aⅴ免费一区二区三区| 亚洲一卡久久| 日韩天堂在线视频| 狠狠久久五月精品中文字幕| 欧美视频中文一区二区三区在线观看| 久久精品亚洲精品| 亚洲一级二级| 亚洲美女尤物影院| 亚洲国产合集| 欧美sm极限捆绑bd| 久久人人九九| 欧美一区日本一区韩国一区| 亚洲深爱激情| 亚洲精品在线三区| 亚洲电影免费观看高清完整版| 国产欧美日韩精品丝袜高跟鞋| 欧美日韩精品久久久| 欧美电影美腿模特1979在线看 | 亚洲国产小视频| 欧美v日韩v国产v| 久久婷婷久久| 久久精品欧美日韩| 久久动漫亚洲| 亚洲欧美日韩网| 亚洲欧美日韩一区在线观看| 亚洲私人影院| 亚洲一区二区综合| 亚洲视频在线观看三级| 一区二区三区国产| 亚洲神马久久| 亚洲在线第一页| 亚洲欧美国产高清| 欧美在线观看天堂一区二区三区| 亚洲欧美日韩一区二区三区在线观看| 亚洲图片在线观看| 午夜视频精品| 欧美在线视频全部完| 久久精品国产999大香线蕉| 久久国产一区二区| 久久久久免费观看| 欧美成人免费在线| 亚洲日本视频| 亚洲私人黄色宅男| 欧美一区三区三区高中清蜜桃 | 亚洲三级影院| 一区二区三区www| 午夜久久久久| 久久久久久久波多野高潮日日 | 午夜在线视频观看日韩17c| 久久大综合网| 欧美激情国产高清| 欧美视频一区二区在线观看 | 欧美伦理91i| 国产精品毛片va一区二区三区| 国产一区二区电影在线观看| 亚洲福利在线视频| 亚洲午夜精品一区二区三区他趣| 亚洲欧美影音先锋| 免费久久99精品国产自在现线| 亚洲国产欧美一区二区三区同亚洲| 99视频精品全部免费在线| 亚洲免费在线| 欧美大片在线观看一区| 国产精品毛片| 91久久久久久久久| 午夜精品亚洲| 亚洲国产精品久久久久婷婷884 | 亚洲国产成人porn| 亚洲欧美日韩第一区| 另类天堂视频在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 国产精品一区二区欧美| 亚洲激情婷婷| 欧美伊久线香蕉线新在线| 亚洲黄页视频免费观看| 欧美影视一区| 欧美日韩在线一区二区| 亚洲高清中文字幕| 久久激情视频久久| 这里只有精品电影| 久久中文精品| 好看的av在线不卡观看| 午夜视频在线观看一区二区三区| 亚洲福利视频免费观看| 欧美亚洲一级| 国产精品嫩草影院av蜜臀|