小言_互联网的博客

C#程序发布时,一定要好好地保护,不然你会后悔的

323人阅读  评论(0)

上次分享一个C#混淆开源项目《一个对C#程序混淆加密,小巧但够用的小工具》,发现大家都非常感兴趣,但也发现很多人,不了解为什么没有混淆,就会很容易被破解。

所以今天给大家做一个教程:如何通过工具来反编译代码、修改代码来实现软件的篡改,并实现通过.NETReactor进行加密混淆

一、演示项目

先创建一个演示项目,方便后续破解和加密使用。

1.1、创建控制台项目:ConsoleAppRemo

1.2、选择框架版本,演示用的是.Net6.0

1.3、实现一个功能:2个数字相加

// See https://aka.ms/new-console-template for more information
int num1 = 3;
int num2 = 4;
Console.Write("num1 + num 2 = ");
Console.WriteLine(num1 + num2);
Console.Read();

1.4、运行效果

二、采用dnSpy破解

下面一起来看看,通过工具对演示项目,进行反编译和修改代码。

2.1、安装dnSpy

dnSpy是Github开源项目,我们到Github下载就行

工具界面:

2.2 、打开dll文件

通过菜单:文件,打开ConsoleAppRemo.dll文件。

2.3、查看代码

通过反编译的结果看,代码完全暴露出来了。

2.4、修改代码

在窗口鼠标右键=》编辑IL指令,打开指令编辑窗口

编辑窗口

2.5、修改变量把数字改为5,并保存

保存效果如下:

2.6、导出dll

选择菜单上的保存按钮,模块类型选择dll,并点击确定,覆盖更新dll。

通过修改时间,我们就可以看到dll已经被更新了

2.7、运行效果

点击exe运行,运行结果已经改变。

到这里,可以说是,我们完完全全地破解了程序了。相信大家看到这,就会发现程序发布时,为什么要进行加密和混淆了。

下面我们一起看看,通过.NETReactor加密情况,以及能否破解。

三、.NET Reactor加密

3.1、下载安装

安装过程比较简单,这里就不展示了。

下载地址:https://www.eziriz.com/reactor_download.htm

3.2、选择待加密的dll文件

选择需要加密的dll文件

3.3、执行加密

点击Protect按钮,进行加密。

3.4、加密成功

工具会自动运行,打印加密的情况(工具是收费的,可免费试用14天)。

执行成功后,工具会创建文件夹,并把加密的文件放入

3.5、检验加密后,我们系统执行情况

拷贝exe文件到Secure文件夹里,并运行,我们的系统可以正常运行

3.6、dnSpy查看反编译情况

通过反编译工具打开加密后的dll,我们会发现文件名、代码都已经被混淆、加密。

总结

通过加密后,还是能比较好地起到保护的效果。通过工具进行加密混淆,主要的目的是增加阅读难度、增加陷阱让破译需要更多的时间与成本。

另外市面上加密工具很多,下面梳理几个比较常用的:

  • ConfuserEx:免费开源的,比较好,只支持.NET Framework,较久未更新。

  • .NET Reactor:收费,比较好,一直有更新。

  • Dotfuscator:收费,比较难用,中间还会出错。

  • Smart Assembly:收费,只有代码混淆,效果不好。

今天就跟大家,分享到这边了,希望对您有帮助**,欢迎点赞关注转发。**

- End -

推荐阅读


转载:https://blog.csdn.net/daremeself/article/details/127948674
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场