gdb命令腳本寫法_第1頁
gdb命令腳本寫法_第2頁
gdb命令腳本寫法_第3頁
gdb命令腳本寫法_第4頁
gdb命令腳本寫法_第5頁
已閱讀5頁,還剩1頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

本文格式為Word版,下載可任意編輯——gdb命令腳本寫法gdb命令腳本寫法

分類:其它2023-03-0621:36309人閱讀評論(0)珍藏舉報

debughacks(中文版)里166頁有一段腳本就是用來設置一些調試操作的。

腳本寫在debug.cmd里,執(zhí)行:gdbtest-xdebug.cmd,就可以啟用腳本里設置的調試信息。===============================================================================

在使用gdb調試程序的時候,有時候需要設定多個斷點,重復執(zhí)行某些操作,而這些操作寫起來比較麻煩,這個時候就應當想起來用gdb命令腳本了,它能夠很好的完成這些工作。以設置多個斷點為例,我寫的命令腳本為#filename:.gdbinit

#gdbwillreaditwhenstartingfiletest_gdbscriptsetargshellobmainbfoor

有兩種方式來使用這個腳本:1)啟動gdb時候

gdb在啟動的時候,會在當前目錄下查找\這個文件,并把它的內容作為gdb命令進行解釋,所以假使我把腳本命名為\,這樣在啟動的時候就會處理這些命令。2)gdb運行期間

可以使用sourcescript-file來解釋gdb命令腳本script-file

==============================================================================

gdb是支持腳本的,不過他支持的是命令序列。

網(wǎng)上的這樣的文章也不多。我在這里就來個gdb腳本反反調試的試驗。

實際上要實現(xiàn)起來也不是很難。ok!我們在原來的基礎上多加幾次反調試的語句。但并沒有增加技術上難度。

我在這里表達的不是反調試的方法而只是如何利用shellscript和gdbscript協(xié)同進行調試。學習進行中

首先還是給出被測試程序的源代碼。

#include#include#include#include#include#include#include

intget_name_by_pid(pid_tpid,char*name){intfd;

charbuf[1024]={0};

snprintf(buf,1024,\if((fd=open(buf,O_RDONLY))==-1)return-1;

read(fd,buf,1024);strncpy(name,buf,1023);return0;}

intcheck_user(){

char*password=\printf(\scanf(\

if(!strcmp(password,user)){printf(\else

{printf(\}

intmain(void){

charname[1024];pid_tppid=getppid();

if(get_name_by_pid(ppid,name))return-1;

if(strcmp(name,\{

pid_tppid=getppid();

if(get_name_by_pid(ppid,name))return-1;

if(strcmp(name,\{

check_user();}

elseif(strcmp(name,\||strcmp(name,\||strcmp(name,\==0)

printf(\else

printf(\}

elseif(strcmp(name,\||strcmp(name,\||strcmp(name,\==0)

printf(\else

printf(\

return0;

}

源碼沒有很大變化,只是在檢測getppid次數(shù)上增加一次。用來說明GDBscript的自動調試方法

gdb的腳本的使用方法也很簡單直接在gdb的命令行中輸入sourcefilename

腳本的內容

echowelcomeuseingMyScript\\nechoGdbScript\\nechoBeijihu\\nrbgetppidcommandsrependdefinerepnext

shellecho`ps-A|grep\shellecho'print$eax=arr'>./anti.temp

shellsed-is@arr@`awk-F'''{print$1}'./gdb.Temp`@g./anti.tempsource./anti.tempshellrm./*.tempcend

詳細解釋一下具體命令的含義:

beijihu's

split-line

r#第一次運行。這個上次說為什么不知道這樣做的原因大約是由于第一次運行需要加載器解決程序的共享函數(shù)庫的重定向的問題

bgetppid#在getppid函數(shù)調用下斷commands#定義getppid斷點的調用命令序列rep#自定義的命令end

definerep#定義一個命令序列next#步過,相當于OD的F8

shellecho`ps-A|grep\#Shell命令

shellecho'print$eax=arr'>./anti.temp#shell命令臨時建立一個gbdscript

shellsed-is@arr@`awk-F'''{print$1}'./gdb.temp`@g./anti.temp#shell命令置換arr為bash的pidsource./anti.temp

#執(zhí)行臨時建的gdb腳本。實際上就是一個print$eax=pidshellrm./*.temp#清理現(xiàn)場c#繼續(xù)運行end#命令序列終止

beijihu's

split-line腳本調用...

(gdb)sourceanti.gdb

運行腳本后以下輸出

welcomeuse

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論