日韩欧美人妻无码精品白浆,www.大香蕉久久网,狠狠的日狠狠的操,日本好好热在线观看

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

如何從 dump 文件中提取出 C# 源代碼?

freeflydom
2024年12月2日 10:31 本文熱度 1694

一:背景

相信有很多朋友在遇到應(yīng)用程序各種奇葩問(wèn)題后,拿下來(lái)一個(gè)dump文件,辛辛苦苦分析了大半天,終于在某一個(gè)線程的調(diào)用棧上找到了一個(gè)可疑的方法,但 windbg 常常是以 匯編 的方式顯示方法代碼的,可惜的是,現(xiàn)如今的匯編,有多少像我們這些速成系碼農(nóng)還看的懂呢? ??????

接下來(lái)尖銳的問(wèn)題就來(lái)了,如何將這些匯編代碼轉(zhuǎn)成 C# 源代碼,如果轉(zhuǎn)不成源代碼轉(zhuǎn)成 IL代碼也好呀,起碼我努努力還是能試著看的懂的。。。

本篇我就來(lái)分享下如何把 dump 中的方法源碼提取出來(lái)。

二: 從 dump 文件中提取源代碼

1. 案例演示

為了能夠演示方便,我用 .netcore 3.1 寫(xiě)了一個(gè)簡(jiǎn)單的demo,代碼如下:


namespace ConsoleApp6
{
    class Program
    {
        static void Main(string[] args)
        {
            Run();
        }
        static void Run()
        {
            Console.WriteLine("hello world!");
            Console.ReadLine();
        }
    }
}

將程序跑起來(lái)后,使用 任務(wù)管理器adplusprocdump 隨便哪一個(gè)抓取 dump 都可以。

2. 使用 lm + savemodule 命令提取

如果你的程序足夠簡(jiǎn)單,可以直接用 lm 獲取程序中所有的模塊,然后使用 savemodule 將模塊導(dǎo)出為 exe/dll 物理文件,如下所示:

  • 使用 lm 提取出所有模塊

0:000> lm
start             end                 module name
000002c2`264b0000 000002c2`264b8000   ConsoleApp6_2c2264b0000   (deferred)             
00007ff7`e4a50000 00007ff7`e4a7f000   ConsoleApp6   (deferred)             
00007ffa`a4b50000 00007ffa`a546d000   System_Private_CoreLib   (deferred)             
00007ffa`a5470000 00007ffa`a59df000   coreclr    (deferred)             
00007ffa`df070000 00007ffa`df1b2000   clrjit     (deferred)             
...

可以隱約的看到,我有一個(gè)名為 ConsoleApp6_2c2264b0000 的模塊,這就是我要提取的 ConsoleApp6.exe,順便提一下,那個(gè)很礙眼的 ConsoleApp6 (deferred) 是 PE 文件,要問(wèn)我怎么知道的? 試一下就好啦??

  • 使用 savemodule 提取

從上面第一行 start 列中可以看到 ConsoleApp6_2c2264b0000 的開(kāi)始地址為 000002c2264b0000,接下來(lái)用 savemodule 導(dǎo)出到 E:\dump。


0:000> !savemodule 000002c2`264b0000 E:\dump\ConsoleApp6.exe
3 sections in file
section 0 - VA=2000, VASize=6c4, FileAddr=200, FileSize=800
section 1 - VA=4000, VASize=564, FileAddr=a00, FileSize=600
section 2 - VA=6000, VASize=c, FileAddr=1000, FileSize=200

然后就可以看到 E:\dump 里面多了一個(gè) ConsoleApp6.exe ??,有了這玩意看源碼就簡(jiǎn)單多了,直接用 ILSpy 對(duì)其進(jìn)行反編譯即可。

3. 使用 dumpdomain/module + savemodule 提取

實(shí)際開(kāi)發(fā)中有可能你的程序非常復(fù)雜,使用 lm 直接提取模塊是找不到的,最好的辦法就是 按圖索驥 的方式尋找你要的 module,還記得 CLR Via C# 上說(shuō)過(guò)的 AppDomain,Assembly,Module 之間的關(guān)系嗎?如果要詳細(xì)了解,建議翻看一下,這里我大概簡(jiǎn)述一下, Assembly 一般包含若干個(gè) Module + 資源文件, Assembly 就是一個(gè) dll/exe 文件,程序跑起來(lái)后,Assembly是被妥善安置在 AppDomain 中的。

有了上面這個(gè)思想,是不是就可以通過(guò)這個(gè)流程 AppDomain -> Assembly -> Module 找到 module 啦? 接下來(lái)看看如何去實(shí)現(xiàn)。

  • 使用 !dumpdomain 找到 ConsoleApp6 所在的程序域

0:000> !dumpdomain
--------------------------------------
System Domain:      00007ffaa59996f0
LowFrequencyHeap:   00007FFAA5999C58
HighFrequencyHeap:  00007FFAA5999CE8
StubHeap:           00007FFAA5999D78
Stage:              OPEN
Name:               None
--------------------------------------
Domain 1:           000002c224b6ca80
LowFrequencyHeap:   00007FFAA5999C58
HighFrequencyHeap:  00007FFAA5999CE8
StubHeap:           00007FFAA5999D78
Stage:              OPEN
Name:               clrhost
Assembly:           000002c224bf1c00 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App\3.1.12\System.Private.CoreLib.dll]
ClassLoader:        000002C224B61820
  Module
  00007ffa45984020    C:\Program Files\dotnet\shared\Microsoft.NETCore.App\3.1.12\System.Private.CoreLib.dll
Assembly:           000002c224bf1980 [E:\net5\ConsoleApp3\ConsoleApp6\bin\Debug\netcoreapp3.1\ConsoleApp6.dll]
ClassLoader:        000002C224BE3F80
  Module
  00007ffa45b5f7d0    E:\net5\ConsoleApp3\ConsoleApp6\bin\Debug\netcoreapp3.1\ConsoleApp6.dll

尷尬,記得不錯(cuò)的話,在 .NET Framework 中默認(rèn)會(huì)有三個(gè)應(yīng)用程序域。

  • System Domain
  • Shared Domain
  • Domain 1

咋到 .NET Core 上就丟了一個(gè) Shard Domain 呢 ??????,先不管啦,從圖中可以清楚的看到 Domian 1 上有我的dll E:\net5\ConsoleApp3\ConsoleApp6\bin\Debug\netcoreapp3.1\ConsoleApp6.dll,同時(shí)還有一個(gè) module 的地址 00007ffa45b5f7d0。

  • 使用 !dumpmodule 獲取 module 詳細(xì)信息

0:000> !DumpModule /d 00007ffa45b5f7d0
Name: E:\net5\ConsoleApp3\ConsoleApp6\bin\Debug\netcoreapp3.1\ConsoleApp6.dll
Attributes:              PEFile SupportsUpdateableMethods 
Assembly:                000002c224bf1980
BaseAddress:             000002C2264B0000
PEFile:                  000002C224BF2300
ModuleId:                00007FFA45B5FB98
ModuleIndex:             0000000000000001
LoaderHeap:              0000000000000000
TypeDefToMethodTableMap: 00007FFA45B3C8D0
TypeRefToMethodTableMap: 00007FFA45B3C8E8
MethodDefToDescMap:      00007FFA45B3C958
FieldDefToDescMap:       00007FFA45B3C978
MemberRefToDescMap:      0000000000000000
FileReferencesMap:       00007FFA45B3C988
AssemblyReferencesMap:   00007FFA45B3C990
MetaData start address:  000002C2264B2078 (1304 bytes)

從上面的 BaseAddress: 000002C2264B0000 可以看出,module 的start 地址為 000002C2264B0000,是不是和剛才我用 lm 提取出來(lái)的地址一致哈,最后用 savemodule 導(dǎo)出一下就可以啦,為了做區(qū)分,我取名為 ConsoleApp7.exe, 如下所示:


0:000> !savemodule 000002C2264B0000 E:\dump\ConsoleApp7.exe
3 sections in file
section 0 - VA=2000, VASize=6c4, FileAddr=200, FileSize=800
section 1 - VA=4000, VASize=564, FileAddr=a00, FileSize=600
section 2 - VA=6000, VASize=c, FileAddr=1000, FileSize=200

哈哈,剩下來(lái)的就是用 ILSpy 反編譯 CosoleApp7 啦。

?轉(zhuǎn)自https://www.cnblogs.com/huangxincheng/p/14646383.html


該文章在 2024/12/2 10:31:11 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

人妻蜜臀AV中文字幕一区| 中文网无码官网字幕| niuganwang好吊妞| 日韩肏日韩| 天天日日天天爽| 加勒比1区2区2区| 日本精品一区二区三区四区五区| 色呦呦在线视频| 国产成人AV午夜福利| 精品黄色片网站| 国产欧美又大又粗的视频| 亚洲一区二区三区文久| 999精品一区二区三区中出合集| 精品人妻无码高清| 亚洲经典在线a| 国产在线精品首页99| 欧美日韩欧无码丁香花| 欧美醴ww| anhwy.com| a级亚洲国一级网站| 综合网五月天| 亚洲综合自拍区| 神马日韩久久久一区| 国产久久久精品2| 夂久黄色片| 久久久伊人一区| 青田县| 1区2区三区精品乱码| 国产精品久久久久久网站| 日日夜夜国产第一| 人人操,操人人| 大香蕉在色| 蜜臀久久亚洲一区| 中文日本视频在线| 91精品久久久久久久久99蜜臂| 日韩欧极品粉嫩| 精品日韩影院| 2020偷自拍亚洲综合精品一区| 丁香五月亚洲综合国产传媒| 亚洲自拍一区 精品| 日本视频久久久久久站|