国产精品久av福利在线观看_亚洲一区国产精品_亚洲黄色一区二区三区_欧美成人xxxx_国产精品www_xxxxx欧美_国产精品久久婷婷六月丁香_国产特级毛片

錦州市廣廈電腦維修|上門維修電腦|上門做系統(tǒng)|0416-3905144熱誠服務,錦州廣廈維修電腦,公司IT外包服務
topFlag1 設為首頁
topFlag3 收藏本站
 
maojin003 首 頁 公司介紹 服務項目 服務報價 維修流程 IT外包服務 服務器維護 技術文章 常見故障
錦州市廣廈電腦維修|上門維修電腦|上門做系統(tǒng)|0416-3905144熱誠服務技術文章
使用IDAPython自動映射二進制文件替換默認函數(shù)名

作者: 佚名  日期:2018-11-10 14:48:23   來源: 本站整理

 這篇文章簡要介紹了我編寫的一個腳本,該腳本用調(diào)試輸出的名稱替換了IDA中的默認函數(shù)名,希望它能為你創(chuàng)建自己的函數(shù)名提供基本知識。
免責聲明:這是我寫的一個小腳本的解釋,它幫助我可以在幾秒內(nèi)(而不是數(shù)周)映射大型二進制文件。我鼓勵任何人修改腳本以供自己使用。我將這段代碼用于我自己的私人研究——如果你發(fā)現(xiàn)它有用或者修復了一個bug,那就要買瓶啤酒好好謝謝我了。存在的問題我遇到的主要問題是我需要映射一個沒有任何符號的大型二進制文件。對于二進制文件的第一個映射,我只有一個有限的時間框架,所以我必須找到一個更有效的方法來做到這一點。我非常喜歡為IDA編寫腳本,尤其是映射部分,這也是我在此情況下所做的。為了自動化映射過程,我使用了一個簡單的方式:查看是否有任何調(diào)試輸出——幸運的是,二進制文件有很多調(diào)試輸出。實例分析從裝配方面來看,調(diào)試輸出真是一個寶藏。它可以顯示函數(shù)的用途,還可以顯示真正的文件名,這有助于理解此函數(shù)所屬的模塊。值得注意的是,我最初研究的代碼是在x64 OS上運行的8086程序集,而大多數(shù)函數(shù)都使用fastcall調(diào)用約定,因此我在我的文章中使用fastcall作為示例。

圖1:調(diào)試輸出帶指示性錯誤字符串

圖2:使用源文件名調(diào)試輸出
查找日志函數(shù)名稱由于這段代碼有太多的調(diào)試輸出,我決定寫一些東西來處理它們。有幾種方法可以找出哪些函數(shù)處理調(diào)試輸出,其中一種方法是根據(jù)其內(nèi)部的libc函數(shù)調(diào)用或行為來查找這些函數(shù),這是一種比較復雜和耗時的方法,但它看起來更優(yōu)雅。第二種方式是快速且粗暴的,特別是當你沒有很多時間又急需時,我建議你使用它。在這種情況下,只需查看可執(zhí)行文件中的字符串并找到可疑的調(diào)試輸出,在找到它們之后,查看一些函數(shù)是否將它們作為參數(shù)接收。如果使用調(diào)試輸出作為參數(shù)重復調(diào)用函數(shù),那么你可以在腳本中使用它。在創(chuàng)建腳本之前,我發(fā)現(xiàn)大約有10個不同的函數(shù)正在處理調(diào)試輸出,并且我還發(fā)現(xiàn)了寄存器中的字符串參數(shù)存儲在其中。我的解決方案我們的目標是根據(jù)調(diào)試輸出更改IDA的默認函數(shù)名稱。例如:

圖3:使用腳本更改函數(shù)名前后
接下來我將闡明腳本的不同部分。把它們放在一起正如我所說的,至少有兩種方法可以找到調(diào)用的日志函數(shù),一個懶人方案,一個非懶人方案。懶人方案遍歷所有程序集并查找“call”指令,然后查找?guī)в腥罩竞瘮?shù)名稱的參數(shù)。我決定將函數(shù)名稱組織為全局字典的一部分:
FUNCTIONS_REGISTERS = {Function_Name:Register, Function_Name_1, Register_1... }
函數(shù)名稱作為鍵,它們的值是調(diào)試輸出的相關寄存器。例如:
FUNCTIONS_REGISTERS = {'g_WriteLogFile': 'rdx', 'g_LogError': 'rdx'}
我為該部分編寫的腳本如下:
curr_addr = MinEA()
end = MaxEA()
while curr_addr 
非懶人方案我想到的不那么懶惰的方法是將xref用于找到的相關函數(shù)。通過這種方式,我使用了相同的函數(shù)名字典。在這里,我所做的是找到每個函數(shù)的外部參照地址,即函數(shù)調(diào)用的地址。
for function_name in FUNCTIONS_REGISTERS.keys():
  func_addr = idc.LocByName(function_name)
    a = idautils.XrefsTo(func_addr, 1)
    for xref in a:
        curr_addr = xref.frm  # ea in func
        if curr_addr == idc.BADADDR:
            pass
獲取函數(shù)參數(shù)這些函數(shù)中包含在調(diào)用指令之前分配的寄存器中存儲的調(diào)試輸出。因為我有調(diào)用指令本身的地址,所以我需要向后查找,并從調(diào)用指令地址開始找到相關的寄存器值。
獲取寄存器分配的地址名稱的代碼如下:
def get_string_for_function(call_func_addr, register):
   """
   :param start_addr: The function call address
   :return: the string offset name from the relevant register
   """
   cur_addr = call_func_addr
   start_addr = idc.GetFunctionAttr(cur_addr, idc.FUNCATTR_START)
   cur_addr = idc.PrevHead(cur_addr)
   # go through previous opcodes looking for assignment to the register
   while cur_addr >= start_addr:
       if idc.GetMnem(cur_addr)[:3] == "lea" and idc.GetOpnd(cur_addr, 0) == register:
           str_func = idc.GetOpnd(cur_addr, 1)
           return str_func
       cur_addr = idc.PrevHead(cur_addr)
   return str_func
我們有調(diào)試輸出地址了,現(xiàn)在我們需要考慮如何得到它引用的實際字符串。下面的代碼顯示了它是如何完成的:(例如:更改“aErrorSavingFil”->“Error saving file %1”。我們可以通過簡單地從其名稱中提取地址然后獲取存儲在其中的字符串來實現(xiàn)。)
 func_name = idc.GetString(idc.LocByName(addr)
從調(diào)試輸出到函數(shù)名在更改函數(shù)名稱之前,我們應該稍微修改調(diào)試輸出格式,因為要呈現(xiàn)的最終函數(shù)名稱應該是干凈且可讀的,因此我在腳本中創(chuàng)建了一個函數(shù)。免責聲明:我在這里介紹的函數(shù)不是我使用的整個函數(shù),它只對調(diào)試輸出進行了一般性更改,如果你想為自己創(chuàng)建這樣的腳本,你應該編寫一個函數(shù)來更改調(diào)試中的相關部分輸出格式。在此函數(shù)中,還從地址名稱中提取調(diào)試輸出字符串。def get_fixed_source_filename(addr):
   """
   :param addr: The address of the source filename string
   :return: The fixed source filename's string
   """
   func_name = idc.GetString(idc.LocByName(addr)).replace("/", "_").replace(" ", "_")
   func_name = "AutoFunc_" + func_name
   # if the debug print is a path, delete the extension
   if func_name.endwith(".c") or func_name.endwith(".h"):
       func_name = func_name[:-2]
   # you can add whatever you want here in order to have your preferred function name
   return func_name
更改函數(shù)名稱更改函數(shù)名是腳本的最后一部分,可以通過運行以下命令輕松完成:
idaapi.set_name(function_start, new_filename, idaapi.SN_FORCE)
值得注意的是,idaapi.SN_FORCE標志只能用于IDA 7及更高版本。錯誤的處理由于我有一個大型的二進制文件,所以我偶爾會發(fā)現(xiàn)一些調(diào)試函數(shù)的不同點,雖然在99.9%的情況下不會發(fā)生錯誤,但我也不能忽略其可能性。即使發(fā)生了一些錯誤,腳本也會繼續(xù)在其他所有的函數(shù)上運行,不過我還是想跟蹤錯誤并更改失敗的函數(shù)名稱。發(fā)生這些錯誤時,消息將顯示在輸出窗口中:

圖4:IDA輸出窗口,出錯
錯誤消息包含失敗的地址,日志函數(shù)名稱和函數(shù)的當前名稱。結(jié)論總的來說,它不是什么高深的事,這通常是我腳本中的所有代碼部分。希望它能幫助人們在他們的道路上增加代碼覆蓋率,或者只是打開他們到IDAPython的神奇世界。我希望你能喜歡這篇文章,也歡迎任何反饋。
 



熱門文章
  • 機械革命S1 PRO-02 開機不顯示 黑...
  • 聯(lián)想ThinkPad NM-C641上電掉電點不...
  • 三星一體激光打印機SCX-4521F維修...
  • 通過串口命令查看EMMC擦寫次數(shù)和判...
  • IIS 8 開啟 GZIP壓縮來減少網(wǎng)絡請求...
  • 索尼kd-49x7500e背光一半暗且閃爍 ...
  • 樓宇對講門禁讀卡異常維修,讀卡芯...
  • 新款海信電視機始終停留在開機界面...
  • 常見打印機清零步驟
  • 安裝驅(qū)動時提示不包含數(shù)字簽名的解...
  • 共享打印機需要密碼的解決方法
  • 圖解Windows 7系統(tǒng)快速共享打印機的...
  • 錦州廣廈電腦上門維修

    報修電話:13840665804  QQ:174984393 (聯(lián)系人:毛先生)   
    E-Mail:174984393@qq.com
    維修中心地址:錦州廣廈電腦城
    ICP備案/許可證號:遼ICP備2023002984號-1
    上門服務區(qū)域: 遼寧錦州市區(qū)
    主要業(yè)務: 修電腦,電腦修理,電腦維護,上門維修電腦,黑屏藍屏死機故障排除,無線上網(wǎng)設置,IT服務外包,局域網(wǎng)組建,ADSL共享上網(wǎng),路由器設置,數(shù)據(jù)恢復,密碼破解,光盤刻錄制作等服務

    技術支持:微軟等
    在线成人免费观看| 在线观看亚洲| 高清精品视频| 亚洲第一福利专区| 黄页网站一区| 亚洲精品亚洲人成在线| 欧美日韩激情| 日本不卡视频在线| 国产欧美丝祙| 艳女tv在线观看国产一区| 日韩中文字幕区一区有砖一区| 成人少妇影院yyyy| 一级中文字幕一区二区| 国产女人水真多18毛片18精品视频| 亚洲激情图片一区| 亚洲国产另类久久精品| 日韩一区国产二区欧美三区| 中文一区二区视频| 亚洲一区亚洲二区| 国产精品专区在线| 亚洲欧洲中文| 久久综合毛片| 激情视频综合网| 北条麻妃在线观看视频| 好吊视频一二三区| 欧美18 19xxx| 黄色的网站免费| 丝袜脚交免费网站xx| 黄色在线观看网| 日韩色性视频| 婷婷综合国产| 午夜视频在线观看精品中文| 亚洲毛片播放| 麻豆一区二区三| 香蕉加勒比综合久久| 这里只有精品视频在线| 久久久婷婷一区二区三区不卡| 久久99精品久久久久久秒播放器| 成人综合视频在线| 久久精品国产露脸对白| 欧洲成人午夜精品无码区久久| 日本五十熟hd丰满| 人与牲动交xxxbbb| 美女在线视频免费| 日韩欧美一区免费| 中文字幕在线免费观看视频| av综合电影网站| 国产一区高清| 日韩高清欧美激情| 欧美日韩成人在线| 亚洲国产精品久久久久久| 国产色综合天天综合网 | theav精尽人亡av| 国产欧美日韩成人| 影音先锋电影在线观看| aⅴ在线视频男人的天堂| av在线网址观看| 欧美电影一二区| 性久久久久久| 成人av影院在线| 一区二区三区日韩精品| 久久综合久久88| 97干在线视频| 久久夜靖品2区| 黄网址在线播放免费| 黄色成人在线观看| 欧美日韩国产色综合一二三四| 精品一区二区三区久久久| 欧美精品123区| 国产精成人品localhost| 黄色片视频免费观看| 性欧美最新另类| 欧美办公室脚交xxxx| 秋霞午夜av一区二区三区| 337p亚洲精品色噜噜狠狠| 国产精品入口免费| av免费观看国产| 亚洲综合成人av| 亚洲色婷婷综合开心网| 色成人亚洲网| 精品按摩偷拍| 日韩黄色免费电影| 91精品国产综合久久精品| 国产精品一级久久久| 成人三级视频在线观看| www在线视频观看| 天海翼精品一区二区三区| 国产精品高清亚洲| 日韩精品资源二区在线| 亚洲v国产v| 在线播放第一页| 成年人免费看毛片| 夜色资源站国产www在线视频| 99久久www免费| 色噜噜偷拍精品综合在线| 在线免费看av不卡| 国产av麻豆mag剧集| 粉嫩av一区二区夜夜嗨| 成年人在线网站| 成人动漫精品一区二区| 欧美激情亚洲综合一区| 69久久精品无码一区二区| 高清在线观看免费韩剧| 国产一卡二卡3卡4卡四卡在线| 天堂av在线资源| 99精品在免费线中文字幕网站一区 | 亚洲欧美日韩另类精品一区二区三区 | 青青色在线视频| 香蕉大人久久国产成人av| 亚洲男人的天堂av| 精品视频在线观看日韩| 免费毛片网站在线观看| 男人的天堂色| www.久久东京| 福利微拍一区二区| 97视频在线观看免费高清完整版在线观看 | 2019国产精品自在线拍国产不卡| 欧美日韩精品综合| bl动漫在线观看| 午夜激情在线视频| 亚洲大胆精品| 另类中文字幕网| 欧美精品国产精品日韩精品| 黄色工厂在线观看| 污污网站在线| 国产aⅴ综合色| 国产精品久久久久高潮| 尤蜜粉嫩av国产一区二区三区| 精品一区二区三区免费爱| 亚洲精品一级二级三级| 日韩精品一区二区在线| 亚洲36d大奶网| 又黄又爽毛片免费观看| 国产精品嫩草99av在线| 不卡中文字幕av| 国产又黄又粗又猛又爽的| 成人在线免费视频| 久久伊人蜜桃av一区二区| 俄罗斯精品一区二区| 国产又粗又猛又爽又黄的| 欧州一区二区三区| 99久久亚洲精品蜜臀| 精品国产乱码久久久久久图片 | 日本不卡一二三区黄网| 清纯唯美亚洲激情| 欧美午夜精品理论片| 黄页免费观看| 精品制服美女丁香| 91免费高清视频| 亚洲一二三精品| 国产网站在线免费观看| 自拍偷在线精品自拍偷无码专区| 蜜月aⅴ免费一区二区三区 | 日本大胆欧美人术艺术动态| 4438全国成人免费| 久久久久亚洲av片无码v| 免费在线黄色av| 波多野结衣视频一区| 国产精品免费在线播放| 日批视频免费播放| 色777狠狠狠综合伊人| 久久成年人视频| 国产精品黄色大片| 北条麻妃一区二区三区在线观看| 精品成人一区二区三区| 色婷婷av777| 第一av在线| 成人h版在线观看| 久久久久网址| 国产变态拳头交视频一区二区 | 在线午夜精品自拍| 国产高清在线免费观看| 久久女人天堂| 亚洲欧洲一区二区在线播放| 青春草国产视频| 黄网站app在线观看下载视频大全官网 | 玖玖精品在线视频| 亚洲国产精品二区| 91精品天堂福利在线观看| 日韩亚洲欧美综合| 久久久久久国产精品无码| 在线观看操人| 国产视频一区在线播放| 青青视频免费在线观看| 黄色一级视频网站| 国产精品国产a| 一区二区三区入口| 麻豆视频网站在线观看| 色哟哟欧美精品| 欧美 变态 另类 人妖| 日韩理论视频| 精品无人国产偷自产在线| 中文字幕66页| 黄色免费在线看| 欧美一区二区私人影院日本| 99精品欧美一区二区| 欧美视频精品全部免费观看| 久久成人人人人精品欧| 性中国xxx极品hd| 日日夜夜一区二区|