为了保证示例的完整性,请先准备好一个 c#写的 exe 程序,或者可以使用我提供的 exe 程序也可以(很简单,为了测试这里仅生成了一个带按钮的 winform,单击按钮提示弹窗)
这里通过 ildasm 反编译 exe 程序得到 il 文件,然后对 il 文件进行修改,用于修改弹窗中的内容
ilasm 所在目录
C:\Windows\Microsoft.NET\Framework64\v4.0.30319\ilasm.exe
ildasm 所在目录
C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.6 Tools\ildasm
以上根据具体情况在自己的目录中查找即可
以下是具体的操作步骤
一、反编译 exe 为 il 文件
双击打开 ildasm –> 点击文件 –> 打开刚刚下载或自己的 exe 程序 –> 点击文件 –> 转储选择 UTF8 –>选择位置保存 il 文件,同时可能会生成一些资源(res)文件,具体如图
接下来就是对 il 文件进行修改,这里以示例提供的 exe 为例,点击按钮时弹出的内容为 message ,这里想要让这个 message 改为 message123
修改后,对 il 文件重新编译为 exe 文件,命令为:
ilasm test.il /output:test.exe
如果需要资源文件,则
ilasm test.il /resource:test.res /output:test.exe
如果要编译为 dll 文件,则
ilasm test.il /dll /output:test.dll
然后再执行 test.exe 并点击按钮,发现弹出的内容已修改为 message123
本文介绍了如何使用微软的ilasm和ildasm工具对.NET程序进行反编译和重新编译。首先,通过ildasm将exe反编译成IL文件,然后修改IL代码以改变程序行为,最后用ilasm将修改后的IL文件编译回exe,实现在不接触源代码的情况下修改程序运行效果。
434

被折叠的 条评论
为什么被折叠?



