C#之反编译之路(一)

本文将介绍微软反编译神器dnSpy的使用方法

c#反编译之路(一)

dnSpy.exe区分64位和32位,所以32位的程序,就用32位的反编译工具打开,64位的程序,就用64位的反编译工具打开(个人觉得32位的程序偏多,如果不知道是32位还是64位,就先用32位的打开试试)

目前只接触到wpf和winform的桌面程序,其他项目还没有接触到,有的项目dnSpy也没办法反编译,比如c++的,还望各路大佬指点

启动软件

双击dnSpy.exe→文件→打开→选择自己需要反编译的程序→确定

这个时候,如果你的项目是完整的,点击启动就能启动程序了

中断于修改为入口点,就可以断点整个程序,启动后你就会发现进入main方法了.这里还有一个作用,如果你的程序双击运行没有反应或者闪退,也可以用这个方法来调试,一步一步的f11到达报错的地方.特别是生产上,没办法装编译器的时候,简直就是神器 ,而且它的信息会更全,步骤会更详细,甚至有些地方比vs断点更好用

断点

如果你试过了从入口点断点启动,你就会发现它断点调试的强大.

需要调试的地方打上断点,启动程序,中断方式选择不要中断,运行到断点处程序会自动停下来

可以看到他和开发环境一样方便,断点在程序排错过程中是巨好用的,一分钟定位bug,特别是生产环境,免安装的dnSpy,又不需要环境配置,打开即使用,谁能不爱

修改代码

修改代码通过编辑方法或编辑类方式进行,具体方式是右键:编辑类/方法,后边具体说说这两个的区别和藏的坑

比如我们要在一份找不到代码的程序里边默认勾选记住密码和自动登录

我们先找到登录界面(首先你得从反编译的代码项目结构中区分是wpf还是winform代码,wpf界面是以baml格式的方式存放在资源下,winform则是存在于cs代码中 )

代码中搜索中文关键字,获得勾选框

转到cs代码,我们看到构造器方法里边有load方法于是我们选择在这里修改代码(如果没有load方法,我们也可以自行添加)

右击,编辑方法,在代码中添加以下代码,编译

csharp 复制代码
				this.cb_automatic_login.IsChecked = true;
				this.cb_remember_password.IsChecked = true;

点击文件→全部保存→启动

这个时候就会发现,原本没有勾选的选择框,进入登录界面就已经勾选了

注意事项

1.反编译之后的代码,方法内的局部变量会被系统自动命名,如:text,text1...text10,且重新dnSpy重新加载程序,系统变量可能会变;

2.编辑代码时,如果有报错,需要先处理错误,比如这种,你需要添加相应的引用

3.断点只能在没有被反编译修改的程序下进行,被修改后的代码无法再被断点

4.代码无法被二次反编译!!! (保存代码后,将程序从dnSpy移除,再重新打开叫做二次反编译)
软件下载地址

下一章将介绍一些更高级的玩法
相关推荐
起名字真南几秒前
【OJ题解】C++实现字符串大数相乘:无BigInteger库的字符串乘积解决方案
开发语言·c++·leetcode
tyler_download12 分钟前
golang 实现比特币内核:实现基于椭圆曲线的数字签名和验证
开发语言·数据库·golang
小小小~13 分钟前
qt5将程序打包并使用
开发语言·qt
hlsd#13 分钟前
go mod 依赖管理
开发语言·后端·golang
小春学渗透14 分钟前
Day107:代码审计-PHP模型开发篇&MVC层&RCE执行&文件对比法&1day分析&0day验证
开发语言·安全·web安全·php·mvc
杜杜的man17 分钟前
【go从零单排】迭代器(Iterators)
开发语言·算法·golang
亦世凡华、18 分钟前
【启程Golang之旅】从零开始构建可扩展的微服务架构
开发语言·经验分享·后端·golang
测试界的酸菜鱼32 分钟前
C# NUnit 框架:高效使用指南
开发语言·c#·log4j
GDAL32 分钟前
lua入门教程 :模块和包
开发语言·junit·lua
李老头探索33 分钟前
Java面试之Java中实现多线程有几种方法
java·开发语言·面试