C#程序采用AOT发布,真的可以避免被反编译?

本文介绍了如何利用.Net7的AOT(Ahead-of-Time)编译特性来增强C#程序的安全性,通过创建一个简单的控制台应用并设置为Aot发布方式,展示了AOT编译后的程序难以被ILSpy和dnSpy等反编译工具反编译,从而有效保护代码不被轻易篡改。
摘要由CSDN通过智能技术生成

上次跟大家分享过,C#程序反编译与篡改代码的教程《C#程序发布时,一定要好好的保护,不然你会后悔的!》,根据这个教程,我们都知道C#程序发布后必须进行加密混淆,不然就是相当于源码直接暴露

随着.Net 7的发布,Native AOT也成为亮点之一,大家都非常关注AOT能否解决被反编译的问题,今天我们就一起来看看。

一、演示项目

先创建一个演示项目,方便后续验证能否反编译。

1.1、创建控制台项目:ConsoleAppAot

图片

项目名:ConsoleAppAot

图片

1.2 选择框架.Net 7

图片

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

// See https://aka.ms/new-console-template for more informationint 
num1 = 1;
int num2 = 2;
Console.WriteLine(num1 + num2);
Console.Read();

图片

1.4 项目修改为Aot发布方式

右键项目=》编辑项目文件,添加Aot发布方式。

<PublishAot>true</PublishAot>

图片

1.5 运行效果

图片

二、采用ILSpy、dnSpy进行反编译

2.1 采用win-x64发布

图片

2.2 发布的文件

从发布后的文件,我们可以看到exe有接近3M,这是因为AOT是通过ilc.exe来加载托管的DLL,然后把这个DLL编译成.Obj文件,所以导致exe文件超大。

图片

2.3 反编译结果

ILSpy反编译:

图片

dnSpy反编译:

图片

通过以上反编译工具查看,采用Aot发布确实能有效解决反编译的问题。

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

- End -

推荐阅读

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程乐趣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值