c# – 保护我的代码不受逆向工程的影响

前端之家收集整理的这篇文章主要介绍了c# – 保护我的代码不受逆向工程的影响前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
正如类似问题 herehere中所讨论的,我想保护我的代码免受逆向工程的影响.

我的情况如Simucal在他的(优秀)答案here中所述:

Basically,what it comes down to is
the only chance you have of being
targeted for source theft is if you
have some very specific,hard to
engineer,algorithm related to your
domain that gives you a leg up on your
competition. This is just about the
only time it would be cost-effective
to attempt to reverse engineer a small
portion of your application.

我确实有这种情况.一种难以设计的算法,对我们的特定领域而言是优雅且有价值的.

经过数月的微调和开发后,最终结果非常紧凑(大约100行代码)和优雅.我想保护代码的这一特定部分免受逆向工程或至少使其合理困难.

该场景是一个用C#编写的富客户端应用程序,我必须部署这部分代码 – 我无法从Web服务执行它.

我认为,由于性能原因(以及跨边界问题),提取代码并在非托管本机二进制文件中重写代码不是一种选择.

最初我想做简单的混淆,但考虑到代码的小,我不认为这会提供很多保护.

理想情况下,我想保护我的整个应用程序,但有两个主要问题似乎使普通的混淆器和第三方打包器难以使用:

>该应用程序提供了一个插件接口,因此不应对某些程序集(和接口/类)进行模糊处理和打包
>我们仍然希望能够在接收错误报告时获得真正的堆栈跟踪 – 这可能是我对映射模糊到真实代码的结果.

将这些问题放在一边(尽管我也很感激这方面的任何意见),保护我的一小部分代码免受逆向工程的好方法是什么?我并不担心任何人改变或破解代码,而是想让它难以理解和逆向工程.

解决方法

你应该对完整的代码进行模糊处理,因为它很难达到那个小小的有价值的部分.代码越小,理解它就越容易.大多数混淆器不应该混淆公共接口,因为那里有许多混淆的库.

但是我认为你应该说服用户没有特别的技巧而不是试图隐藏它.引用Kaiser Soze的话说,“魔鬼曾经拉过的最大伎俩就是说服世界他不存在”.

当然,您可以随时为您的发明申请专利并合法保护自己.

猜你在找的C#相关文章