介绍
https://github.com/dnSpy/dnSpy
是一款.Net平台的集反编译器、程序集编辑器和调试器的利器
功能
反编译
● 用dnSpy打开对应Dll(Ctrl+O)
● 查看源码
无源码调试
● 用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
● 用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
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。