目录
- 前言
- 一、使用 ildasm 反编译 dll 文件
- 二、使用 ilasm 将il文件编译成 dll 或 exe 文件
前言
文本讲述怎么通过 ildasm 工具将 dll 文件进行反编译为 il 文件,修改 il 文件后再如何通过 ilasm 工具将 il 文件反编译成 dll 或 exe 文件。
ildasm工具:用于将dll文件反编译成可读的 il 文件(il是.NET框架中中间语言的缩写)
ilasm工具:用于将il文件编译成可执行的dll或exe文件
如果你安装了 Visual Studio 开发工具它会自带这两个工具,不安装的话可能会找不到,这两个工具和.NET框架开发语言的编译和反编译有关。
一、使用 ildasm 反编译 dll 文件
1.双击ildasm.exe运行ildasm工具。
ildasm 工具位置:
C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\ildasm.exe
2.把要反编译的 dll 文件拖入运行的 ildasm 里
效果如下:
你可以点击树形图展开查看所有的类和方法。
可以看到 IL_0000: ldarg.1、IL_0006: ret这样的指令,这些指令就对应着不同的含义和执行顺序,简单来说可读代码最终就是编译成为了这样的操作指令,计算机就是根据这些指令去操作和执行的。
关于 il 文件的指令可以参考如下文章:
IL指令详细
ILDasm反编译工具的基础知识
读懂IL代码就这么简单
C# 构造函数避免IL(反编译)代码膨胀的方法
3.把要反编译的 dll 文件转储为il文件
点击文件选择转储,点击确定,选择转换后位置和输入转换后的文件名
然后你就得到了一个反编译后的 il 文件格式的文件,你可以用常见的文本编辑器打开并进行编辑和修改。
二、使用 ilasm 将il文件编译成 dll 或 exe 文件
上面你已经得到了反编译的 il 文件,等你修改好了 il 文件,可以通过使用 ilasm 工具将 il 文件编译成 dll或 exex 文件。
介绍下 ilasm 工具位置:
C:\Windows\Microsoft.NET\Framework64\v4.0.30319\ilasm.exe
1.cmd 命令行进入il 文件所在目录,然后输入类似如下命令:
C:\Windows\Microsoft.NET\Framework64\v4.0.30319\ilasm.exe FiddlerBackendSDK.il /output=FiddlerBackendSDK.dll /dll
说明:该命令调用 ilasm.exe 程序把当前目录的 FiddlerBackendSDK.il 文件编译成FiddlerBackendSDK.dll并输出到当前目录,你可以改成你的文件名和输出文件名。然后你就得到了编译好后的 dll 文件