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

曲徑通幽

programming_with_fun();

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  18 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

常用鏈接

留言簿(6)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

這是從別人博客上摘的一段C嵌匯編碼
( http://m.shnenglu.com/kevinlynx/archive/2011/01/02/137886.html )
__declspec(naked)
void caller(void* pfn, 
{
    __asm 
    {
        pop eax;
        add eax, 3;
        xchg dword ptr[esp], eax;
        push eax;
        ret;
    }
}
下面是調用方法
void print_str( const char *s )
{
    printf( "%s\n", s );
}

{
   ...
caller( print_str, "a string" );
   __asm  add esp, 4
   ...
}

  原作者講了一些基礎,這里就不提了
看了一遍,發現 "ADD EAX, 3" 的用法有點奇怪(我相信搞破解的人一定比較熟悉,但正常的程序不會這么寫。)
初看 EAX 是地址,+3是很危險的,但仔細一看,發現代碼是為了從最外層主調函數一路穿越"caller" 直達 print_str,這里牽涉到一個重要問題,就是在CALL指令時,會有將“CALL指令下一條地址壓棧”的操作,那么代碼思路很明了了,就是為了要造出 調用print_str時,ESP(+0) 指向 caller(..)調用的下一個地址。
  第一關已經順利搞定,但又碰到個問題,由于 print_str 的入參是可變的,所以必須用 cdecl調用,那RET之后 如何平棧呢? 如果直接跳到 caller下一條地址,就喪失了平棧的機會,最終會在某個主調函數上被微軟的 stack cookie捕獲拋個SEH。
  這里就用到文章開頭提到的 ADD EAX, 3。
  必須要造一個環境,讓 caller 調用完成后,給個機會清理現場。于是乎,caller之后就有了 ADD ESP, 4。其實這里的4是與print_str的入參數目相關的,每個參數要多加 4字節,如此一來,整個代碼就理順了。
  那為什么 是 ADD EAX, 3呢? 應該是預估出一條ADD指令占用多少長度,和具體的環境有關。因為沒看INTEL手冊,這里只能認為ADD 寄存器+WORD的長度是3個字節。我用VC試驗了一下,的確是如此,我也嘗試了ADD 寄存器+DWORD,長度變為了5個字節。
posted on 2011-01-06 12:48 Meiosis 閱讀(482) 評論(0)  編輯 收藏 引用 所屬分類: Windows GenericDebug \ Reverse Engineering
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            女同一区二区| 免费一级欧美在线大片| 欧美一区二区三区视频| 亚洲精品国产精品国自产在线| 国产精品免费网站在线观看| 欧美人成在线视频| 另类av导航| 久久久亚洲人| 久久久久88色偷偷免费| 久久精品91久久香蕉加勒比| 久久精品国产亚洲aⅴ| 亚洲一区二区三区激情| 亚洲第一级黄色片| 久久精品在线视频| 久久全国免费视频| 久久久久免费观看| 先锋影音久久| 久久精品久久99精品久久| 久久久久**毛片大全| 亚洲精品一区二区三| 亚洲精品一区二区三区在线观看| 亚洲经典一区| 一区二区三区国产盗摄| 亚洲系列中文字幕| 先锋影音国产精品| 久久久久久久成人| 亚洲高清影视| 亚洲一区二区在线观看视频| 久久精品一区四区| 欧美激情综合色| 国产精品高潮呻吟| 国产综合一区二区| 亚洲精品精选| 亚洲人成亚洲人成在线观看图片 | 亚洲图片在线观看| 欧美一区二区三区在| 免费黄网站欧美| 亚洲理论在线| 久久www成人_看片免费不卡| 欧美成人dvd在线视频| 国产精品美女久久久久久免费| 国产亚洲激情在线| 一本色道综合亚洲| 久久综合综合久久综合| 亚洲美女av电影| 亚洲一级片在线看| 亚洲欧美在线aaa| 免费观看亚洲视频大全| 精品av久久707| 一区精品在线| 一二三区精品| 久久一区二区三区四区五区| 亚洲精选视频在线| 久久久噜噜噜久久中文字幕色伊伊| 欧美日本二区| 亚洲精品老司机| 久久久无码精品亚洲日韩按摩| 久久福利资源站| 日韩视频中文字幕| 久久精品一区二区国产| 国产精品视频| 亚洲无限乱码一二三四麻| 欧美韩日亚洲| 久久影视精品| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲自拍另类| 亚洲免费成人av| 亚洲免费视频观看| 国产精品久久久久久久久久直播| 一区二区三区四区五区视频| 91久久久久久| 欧美成人午夜激情| 亚洲国产一区二区a毛片| 久久久久久亚洲精品杨幂换脸 | 一区二区三区精品视频| 欧美成人亚洲成人日韩成人| 久久精品一区二区| 在线国产精品播放| 欧美一区精品| 亚洲欧美日韩网| 国产精品任我爽爆在线播放| 亚洲一区二区三区在线看| 久久综合久久综合久久| 日韩亚洲国产精品| 欧美日韩成人一区二区| 一本色道久久88综合亚洲精品ⅰ | 狼人社综合社区| 久久精品一区四区| 国产精品亚发布| 久久免费观看视频| 久久综合网hezyo| 亚洲第一主播视频| 亚洲国产成人久久综合| 欧美日韩四区| 欧美一区二区视频在线观看2020 | 亚洲精品日韩激情在线电影| 欧美黄在线观看| 另类综合日韩欧美亚洲| 国产精品久久久久久影视| 亚洲一级二级| 性伦欧美刺激片在线观看| 国内精品视频666| 欧美激情精品久久久| 久久婷婷久久| 一区二区三区欧美日韩| 亚洲宅男天堂在线观看无病毒| 欧美四级在线观看| 欧美在线一区二区| 久久久www成人免费毛片麻豆| 亚洲激情二区| 欧美激情精品| 国产精品美女视频网站| 免费日韩成人| 国产精品国产三级国产a| 久久久久综合| 欧美三级在线| 牛夜精品久久久久久久99黑人| 欧美韩日一区二区| 久久精品国产一区二区电影| 欧美精品一卡| 久久婷婷一区| 欧美在线观看网址综合| 狠狠综合久久| 制服丝袜亚洲播放| 亚洲欧洲三级电影| 午夜一区二区三视频在线观看| 在线观看日韩| 亚洲欧美高清| 一区二区免费在线视频| 久久精品一区二区三区不卡| 亚洲综合二区| 久久综合狠狠综合久久综合88| 亚洲一区二区在线播放| 美女国产一区| 久久精品中文字幕一区二区三区| 欧美日韩在线一区二区| 亚洲国产精品久久精品怡红院| 国产一区二区三区四区三区四| 一区二区日韩精品| 亚洲精品日韩久久| 巨胸喷奶水www久久久免费动漫| 亚洲福利小视频| 欧美中文字幕在线观看| 午夜激情综合网| 国产精品夫妻自拍| av成人毛片| 中文无字幕一区二区三区| 免费亚洲婷婷| 麻豆精品一区二区av白丝在线| 国内外成人免费激情在线视频| 欧美在线亚洲一区| 亚洲电影免费观看高清完整版在线| 亚洲精品久久久久久久久| 欧美电影免费| 日韩亚洲欧美精品| 欧美一区二区免费观在线| 红桃视频一区| 欧美精品自拍| 亚洲欧美日韩国产综合在线| 老司机一区二区三区| 夜夜嗨av一区二区三区免费区| 国产精品久久久免费| 国产精品啊啊啊| 欧美精品国产| 亚洲免费av电影| 久久久久久久性| 亚洲精品视频免费在线观看| 国产精品人人爽人人做我的可爱 | 欧美另类专区| 亚洲天堂视频在线观看| 久久亚洲不卡| 亚洲少妇诱惑| 亚洲第一在线综合在线| 国产精品成人免费精品自在线观看| 欧美在线观看视频| 99视频精品免费观看| 久久免费视频在线观看| 亚洲视频大全| 亚洲国产精品电影| 国产精品亚洲网站| 欧美精品日韩一区| 久久精品免费看| 亚洲视频一起| 亚洲国产一区二区三区青草影视| 欧美在线免费视屏| 亚洲图片欧美日产| 亚洲精品欧洲精品| 在线成人性视频| 国产欧美在线看| 欧美日韩一区二区三| 美女视频网站黄色亚洲| 午夜在线电影亚洲一区| 中国日韩欧美久久久久久久久| 亚洲大黄网站| 免费观看一区| 美日韩免费视频| 久久人人看视频| 久久精品国产精品亚洲综合| 亚洲一区欧美二区| 亚洲少妇中出一区|