日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
緩沖區(qū)溢出實(shí)戰(zhàn)教程系列(一):頭籌緩沖區(qū)溢出小程序

在安全圈里我們會(huì)經(jīng)常聽到或用到一些0day漏洞,在印象里我們都覺(jué)的只有真正的大神才能挖掘到這樣的漏洞,事實(shí)也的確如此。不過(guò)也不要被嚇到,其實(shí)大部分的0day是緩沖區(qū)溢出漏洞演化而來(lái),只要我們了解了緩沖區(qū)溢出原理,假以時(shí)日也可以自己挖掘出0day漏洞。

由于是本系列的開篇,所以不給大家講解過(guò)多的原理,今天先讓大家直觀感受一下什么是緩沖區(qū)溢出,讓各位有一個(gè)初步的認(rèn)識(shí),閑話少敘,讓我們開始。

給大家一段c語(yǔ)言編寫的代碼,大家在DEV中編譯執(zhí)行一下:

 
 
 
 
  1. #include  
  2. #include      
  3. char name[] = "kalikingkalikingkaliking" ;     
  4. int main() 
  5.  char buffer[8]; 
  6.  strcpy(buffer, name); 
  7.  printf("%s\n",buffer); 
  8.  getchar(); 
  9.  return 0; 
  10. }

在win7中會(huì)出現(xiàn)以下報(bào)錯(cuò),如圖所示:

有一點(diǎn)c語(yǔ)言基礎(chǔ)的人就不難看出問(wèn)題所在,在程序中我們要把變量name的值拷貝給變量buffer,但我們分配給變量的空間只有8個(gè)字節(jié),而name的長(zhǎng)度遠(yuǎn)遠(yuǎn)大于8個(gè)字節(jié)。這就導(dǎo)致系統(tǒng)原本分配的空間不足而占用了本來(lái)用于存儲(chǔ)程序返回地址的空間,導(dǎo)致程序無(wú)法正常運(yùn)行。

今天先不講原理,先講講分析緩沖區(qū)溢出必備的幾款軟件:

1. Dev-C ++是一個(gè)免費(fèi)的全功能集成開發(fā)環(huán)境(IDE),分布在GNU通用公共許可證下,用于 C和C ++編程。它是用Delphi編寫的。

免費(fèi)下載地址:://sourceforge.net/projects/orwelldevcpp/files/latest/download

2. OllyDbg(以其作者Oleh Yuschuk命名)是一個(gè)強(qiáng)調(diào)二進(jìn)制代碼分析的x86調(diào)試器。

免費(fèi)下載地址:http://www.ollydbg.de/odbg201.zip

3. IDA(Interactive Disassembler)是反匯編為計(jì)算機(jī)軟件,其生成匯編語(yǔ)言源代碼從機(jī)器可執(zhí)行代碼。它支持多種可執(zhí)行文件格式為不同的處理器和操作系統(tǒng)。它還可以用作Windows PE,Mac OS X Mach-O和Linux ELF可執(zhí)行文件的調(diào)試器。

免費(fèi)版下載地址:https://www.hex-rays.com/products/ida/support/download_freeware.shtml

接下來(lái)介紹一下三個(gè)軟件的基本使用方法:

在這里只介紹在程序分析過(guò)程中常用的方法,其余的詳細(xì)使用教程請(qǐng)自行Google

1. Dev c++的使用方法:

(1) 新建源代碼文件

由于我們編寫的源代碼,只為了了解緩沖區(qū)溢出的原理,所以不必過(guò)于復(fù)雜,我們只需要新建個(gè)源代碼文件就可以了,沒(méi)必要?jiǎng)?chuàng)建項(xiàng)目文件。

把我們上邊的示例代碼拷貝進(jìn)去,保存與其他編輯器無(wú)異,ctrl+s就ok,我習(xí)慣保存成c文件,這個(gè)大家隨意。

(2) 編譯運(yùn)行:

編譯運(yùn)行就很簡(jiǎn)單了,點(diǎn)擊工具欄最上方的運(yùn)行,接著在下拉菜單中找到編譯和運(yùn)行,點(diǎn)擊:

這時(shí)候會(huì)看到文件夾中多了一個(gè)exe文件這就是我們要用來(lái)調(diào)試的程序:

(3) 調(diào)試和查看匯編代碼

這個(gè)是比較重要的一步,因?yàn)樵诰帉憇hellcode的時(shí)候會(huì)用到,這里只講用法,如何提取shellcode以后再講。

首先設(shè)置斷點(diǎn),選擇設(shè)置斷點(diǎn)的行,可以再前面行標(biāo)出單擊也可以按F4,當(dāng)行標(biāo)處出現(xiàn)紅點(diǎn)說(shuō)明斷點(diǎn)設(shè)置成功。

然后開啟調(diào)試模式,我們點(diǎn)擊下方選項(xiàng)卡里的調(diào)試,接著點(diǎn)擊調(diào)試按鈕。

接著點(diǎn)擊查看CPU窗口:

我們就會(huì)看到匯編代碼界面:

dev c++幾個(gè)重要用法已經(jīng)說(shuō)完了,還要跟大家說(shuō)一下如何解決安裝使用過(guò)程中經(jīng)常會(huì)出現(xiàn)zlib2.dll文件丟失的問(wèn)題。

解決辦法如下:

a. 下載zlib1.dll:

http://www.pc6.com/softview/SoftView_81060.html

b. 解壓后放到系統(tǒng)目錄中

  • 32位系統(tǒng):放到C:\Windows\System32\(此處為系統(tǒng)目錄)
  • 64位系統(tǒng):放到C:\Windows\SysWOW64\

為了不使篇幅過(guò)長(zhǎng),其余兩個(gè)軟件使用方法我將在下一篇文章中進(jìn)行講解。


當(dāng)前標(biāo)題:緩沖區(qū)溢出實(shí)戰(zhàn)教程系列(一):頭籌緩沖區(qū)溢出小程序
網(wǎng)頁(yè)地址:http://www.5511xx.com/article/dpghcdo.html