LyScript獲取上一條與下一條匯編指令的方法詳解
LyScript 插件默認(rèn)并沒(méi)有提供上一條與下一條匯編指令的獲取功能,當(dāng)然你可以使用LyScriptTools工具包直接調(diào)用內(nèi)置命令得到,不過(guò)這種方式顯然在效率上并不理想,我們需要在LyScript插件API基礎(chǔ)上自己封裝實(shí)現(xiàn)這個(gè)功能。
LyScript項(xiàng)目地址:https://github.com/lyshark/LyScript
獲取下一條匯編指令
下一條匯編指令的獲取需要注意如果是被命中的指令則此處應(yīng)該是CC斷點(diǎn)占用一個(gè)字節(jié),如果不是則正常獲取到當(dāng)前指令即可。
1.我們需要檢查當(dāng)前內(nèi)存斷點(diǎn)是否被命中,如果沒(méi)有命中則說(shuō)明此處我們需要獲取到原始的匯編指令長(zhǎng)度,然后與當(dāng)前eip地址相加獲得。
2.如果命中了斷點(diǎn),則此處有兩種情況
1.1 如果是用戶下的斷點(diǎn),則此處調(diào)試器會(huì)在指令位置替換為CC,也就是匯編中的init停機(jī)指令,該指令占用1個(gè)字節(jié),需要eip+1得到。
1.2 如果是系統(tǒng)斷點(diǎn),EIP所停留的位置,則我們需要正常獲取當(dāng)前指令地址,此處調(diào)試器沒(méi)有改動(dòng)匯編指令僅僅只下下了異常斷點(diǎn)。
from LyScript32 import MyDebug
# 獲取當(dāng)前EIP指令的下一條指令
def get_disasm_next(dbg,eip):
next = 0
# 檢查當(dāng)前內(nèi)存地址是否被下了絆子
check_breakpoint = dbg.check_breakpoint(eip)
# 說(shuō)明存在斷點(diǎn),如果存在則這里就是一個(gè)字節(jié)了
if check_breakpoint == True:
# 接著判斷當(dāng)前是否是EIP,如果是EIP則需要使用原來(lái)的字節(jié)
local_eip = dbg.get_register("eip")
# 說(shuō)明是EIP并且命中了斷點(diǎn)
if local_eip == eip:
dis_size = dbg.get_disasm_operand_size(eip)
next = eip + dis_size
next_asm = dbg.get_disasm_one_code(next)
return next_asm
else:
next = eip + 1
next_asm = dbg.get_disasm_one_code(next)
return next_asm
return None
# 不是則需要獲取到原始匯編代碼的長(zhǎng)度
elif check_breakpoint == False:
# 得到當(dāng)前指令長(zhǎng)度
dis_size = dbg.get_disasm_operand_size(eip)
next = eip + dis_size
next_asm = dbg.get_disasm_one_code(next)
return next_asm
else:
return None
if __name__ == "__main__":
dbg = MyDebug()
dbg.connect()
eip = dbg.get_register("eip")
next = get_disasm_next(dbg,eip)
print("下一條指令: {}".format(next))
prev = get_disasm_next(dbg,12391436)
print("下一條指令: {}".format(prev))
dbg.close()
獲取結(jié)果如下:

獲取上一條匯編指令
上一條指令的獲取難點(diǎn)就在于,我們無(wú)法確定當(dāng)前指令的上一條指令到底有多長(zhǎng),所以只能用笨辦法,逐行掃描對(duì)比匯編指令,如果找到則取出其上一條指令即可。
from LyScript32 import MyDebug
# 獲取當(dāng)前EIP指令的上一條指令
def get_disasm_prev(dbg,eip):
prev_dasm = None
# 得到當(dāng)前匯編指令
local_disasm = dbg.get_disasm_one_code(eip)
# 只能向上掃描10行
eip = eip - 10
disasm = dbg.get_disasm_code(eip,10)
# 循環(huán)掃描匯編代碼
for index in range(0,len(disasm)):
# 如果找到了,就取出他的上一個(gè)匯編代碼
if disasm[index].get("opcode") == local_disasm:
prev_dasm = disasm[index-1].get("opcode")
break
return prev_dasm
if __name__ == "__main__":
dbg = MyDebug()
dbg.connect()
eip = dbg.get_register("eip")
next = get_disasm_prev(dbg,eip)
print("上一條指令: {}".format(next))
dbg.close()
輸出效果如下:

到此這篇關(guān)于LyScript獲取上一條與下一條匯編指令的方法詳解的文章就介紹到這了,更多相關(guān)LyScript獲取匯編指令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決python nohup linux 后臺(tái)運(yùn)行輸出的問(wèn)題
今天小編就為大家分享一篇解決python nohup linux 后臺(tái)運(yùn)行輸出的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
Python實(shí)現(xiàn)在Excel中繪制可視化大屏的方法詳解
今天小編來(lái)給大家分享如何在Excel文檔當(dāng)中來(lái)繪制可視化圖表,并且制作一個(gè)可視化大屏。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-01-01
Appium+Python自動(dòng)化測(cè)試之運(yùn)行App程序示例
這篇文章主要介紹了Appium+Python自動(dòng)化測(cè)試之運(yùn)行App程序示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
Python基礎(chǔ)globlal nonlocal和閉包函數(shù)裝飾器語(yǔ)法糖
這篇文章主要為大家介紹了Python基礎(chǔ)globlal nonlocal和閉包函數(shù)裝飾器語(yǔ)法糖示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
python通過(guò)郵件服務(wù)器端口發(fā)送郵件的方法
這篇文章主要介紹了python通過(guò)郵件服務(wù)器端口發(fā)送郵件的方法,涉及Python發(fā)送郵件的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04
實(shí)例詳解Python中的numpy.abs和abs函數(shù)
Numpy是python中最有用的工具之一,它可以有效地處理大容量數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Python中numpy.abs和abs函數(shù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
Python中發(fā)布Web應(yīng)用的常見方法與對(duì)比
這篇文章主要為大家詳細(xì)介紹了Python中發(fā)布?Web?應(yīng)用的幾種常見方法的實(shí)現(xiàn)詳細(xì)步驟以及它們的部署方法對(duì)比,有需要的小伙伴可以參考下2025-02-02

