dnspy修改任意内容就编译报错的解决方法 .NET软件反编译

  • 1.打开dnspy.exe
  • 2.点击文件-->打开,选择要调试的dll,点击调试-->启动调试,选择要调试的应用程序,一般为.exe;或者点击调试-->附加到进程,选择正在运行的程序
  • 或直接选.exe文件
  • 3.找到要修改的地方,右键 编辑方法
  • 4.点下面编译,什么也没报错,并退出编辑即正常。可以在主窗口看到改后的代码。此时调试程序还是原来的。
  • 5.点击菜单栏-->文件->保存模块 或者全部保存.(如果为dll,使用新的dll替换老的dll)保存为新.exe文件,运行它就是改后的软件了。

参考:使用反编译工具dnspy动态修改代码_dnspy无法编译_Bird鸟人的博客-CSDN博客

建议选择编辑方法,因为这样在编译的时候只会编译这个方法单元,而不会编译这个类,若编辑整个类,编译的时候会报比较多的错误,需要修复

有时候错误会很奇怪,明明有这个变量,却提示没有,这时可以对比下真正的源代码,你会发现,反编译后的代码是错的,会自动添加一些莫名其妙的逻辑,尤其是在使用匿名函数的时候,这个时候就需要我们手动删除这些错误的逻辑,是的没错,你不太可能用dnsny对应用程序做大量的修改,hook整个程序(如果有大神这么干了,请告诉我怎么做!) ,一般只是做一些外科式手术般的改动,既修改一些关键地方,做一些小的改动,那么就可以尝试删除一些错误的代码和无关的代码,使编译能通过!

1.要减少修改范围。比如只改方法就可以,就不要修改类,因为类需要更多的。

2.少引用

3.无关的全删了

复制代码
private bool LicenseCheck()
{

	return true;
}
相关推荐
拳打南山敬老院14 分钟前
Context 不是压缩出来的,而是设计出来的
前端·后端·aigc
用户30767528112718 分钟前
💡 从"傻等"到"流淌":我在AI项目中实现流式输出的血泪史(附真实代码+深度解析)
前端
bluceli19 分钟前
前端性能优化实战指南:让你的网页飞起来
前端·性能优化
SuperEugene21 分钟前
Vue状态管理扫盲篇:如何设计一个合理的全局状态树 | 用户、权限、字典、布局配置
前端·vue.js·面试
没想好d22 分钟前
通用管理后台组件库-9-高级表格组件
前端
阿虎儿25 分钟前
React Hook 入门指南
前端·react.js
核以解忧1 小时前
借助VTable Skill实现10W+数据渲染
前端
WangHappy1 小时前
不写 Canvas 也能搞定!小程序图片导出的 WebView 通信方案
前端·微信小程序
李剑一1 小时前
要闹哪样?又出现了一款新的格式化插件,尤雨溪力荐,速度提升了惊人的45倍!
前端·vue.js
闲云一鹤1 小时前
Git LFS 扫盲教程 - 你不会还在用 Git 管理大文件吧?
前端·git·前端工程化