其他分享
首页 > 其他分享> > dnSpy介绍

dnSpy介绍

作者:互联网

介绍

https://github.com/dnSpy/dnSpy
是一款.Net平台的集反编译器、程序集编辑器和调试器的利器

功能

反编译

● 用dnSpy打开对应Dll(Ctrl+O)
● 查看源码

无源码调试

image

● 用dnSpy打开对应Dll(Ctrl+O)
● 找到需要打断点的方法行并设置断点(F9)
● 调试启动对应进程F5或者附加到进程(Ctrl+Alt+P)

常见问题

Q: 调试Release版本,无法获取变量值
A: 参考:https://github.com/dnSpy/dnSpy/wiki/Making-an-Image-Easier-to-Debug
当附加到一个的 .NET 进程时,它很可能已经过优化(Release版本)。这将使调试体验变得更糟,因为调试器无法读取所有局部变量或评估表达式或调用方法。如果可能,您应该始终让 dnSpy 调试器启动该进程。
如果您必须附加到进程,Microsoft 建议创建一个 INI 文件。
如果您的 DLL 名为something.dll,则创建一个something.ini在同一文件夹中
something.ini包含以下内容:

[.NET Framework Debugging Control]
GenerateTrackingInfo=1
AllowOptimize=0

注意:确保您保存的文件不要是UTF8 BOM格式!要保存为纯粹的UTF8格式也就是UTF8 without BOM
请注意,您必须对想查看变量值所在的EXE/DLL(启动EXE会依赖它们)执行此操作,仅启动的EXE执行此操作是不够的。
设置环境变量COMPlus_ZapDisableto 1和COMPlus_ReadyToRunto 0也可用于禁用加载本机图像。

捕获异常

● 用dnSpy打开对应Dll(Ctrl+O)
● Debug=>Windows=>Exception Settings(Ctrl+Alt+E)
● 全选(Ctrl+A)=>空格(Space)勾选中所有异常
● 调试启动对应进程F5或者附加到进程(Ctrl+Alt+P)
这样就会发生任何异常时候就跳转到抛错方法的对应代码行

修改IL

可以用来破解或者临时修复Bug
image

● 用dnSpy 打开 对应Dll
● 找到需要修改的类或者方法
● 选中方法 右键 选中Edit Method(Ctrl+Shift+E)
● File->Save All (Ctrl+Shift+S)
● 修改保存的路径 文件名 即可,注意最好不要覆盖原Dll

标签:Ctrl,介绍,Dll,dnSpy,进程,对应,调试
来源: https://www.cnblogs.com/KSPT/p/16688431.html