Chinaunix首页 | 论坛 | 博客
  • 博客访问: 6540158
  • 博文数量: 915
  • 博客积分: 17977
  • 博客等级: 上将
  • 技术积分: 8846
  • 用 户 组: 普通用户
  • 注册时间: 2005-08-26 09:59
个人简介

一个好老好老的老程序员了。

文章分类

全部博文(915)

文章存档

2022年(9)

2021年(13)

2020年(10)

2019年(40)

2018年(88)

2017年(130)

2015年(5)

2014年(12)

2013年(41)

2012年(36)

2011年(272)

2010年(1)

2009年(53)

2008年(65)

2007年(47)

2006年(81)

2005年(12)

分类: Android平台

2017-09-25 22:52:43

老实说,发布一个库、桌面应用程序或移动应用程序可能有点吓人。一旦你的软件可以免费提供给世界,你就失去了如何使用它的某种程度的控制权。特别是,开发人员经常担心逆向工程的威胁。

在许多平台和语言中,代码混淆工具是防止逆向工程的常见方法。例如,如果你是一个Android开发者,你可能已经使用到收缩和混淆的java代码。

现在,Xamarin的开发商获得同样的保护,在所有主要的移动设备的家庭,将Android和iOS移植到通用的Windows(UWP)。完成这个工作 的工具叫做 , 在 Visual Studio中已经可以使用了。

今天,我将解释如何混淆可以保护Xamarin。Android应用程序从逆向工程,以及如何你可以把同样的保护自己的Xamarin程序简单的几个步骤。

混淆如何保护应用程序

混淆是一个应用程序编译的代码转换成功能相同但难于逆向工程的代码的过程。通常,这是由一个自动混淆工具完成的,比如 obfuscator。下面是一个简单的例子,演示如何防止反工程混淆应用程序。

考虑下面的一个Xamarin.Android 游戏源代码中的一个C#方法:

当这个游戏的开发人员准备将它部署到设备上,或者上传到应用程序商店时,他们将源代码编译成库,然后将这些库打包到一个应用程序包中。在这个例子中,开发商包库到Android设备上分配一个apk文件。

然而,一旦应用程序发布到App Store,一个糟糕的演员可以很容易地获取和逆向APK,生产反编译的代码,和原始的源代码几乎相同:

注意,类型、方法和成员标识符在这里与源代码中的标识符相同,即使这些代码元素通常不能从项目外部访问(也就是说,它们被标记为internal)。internal要注意,该方法的一般控制流,如if语句的顺序,是显而易见的。 

如果,在分发的apk,开发商也通过Dotfuscator社区版混淆这个库,逆向工程的结果会不同:

代码已被重命名混淆保护,代码混淆的一种基本形式。名称简单的属性, 比如ArrowsOnHand,取而代之的是方法调用与直观的名字, 诸如b 和 g。其他代码元素也同样被重命名。这使得对反编译后的代码更难阅读和推理,作为重要的上下文线索提供的名称不可用。

重命名混淆是这个博客文章的主要焦点,但是我们将讨论更高级的混淆形式,以及如何在以后应用它们。

如何保护你的应用程序

现在,让我们来看看如何整合Dotfuscator 社区版重合名混淆到你的Xamarin构建管道中。作为一个例子,我将使用Xamarin.Android应用程序在上一节中提到的。你可以按照你自己的Xamarin APP,包括iOS和UWP。

我们将使用 , 一个 .NET 混淆器和保护工具,现在也支持Xamarin。

注:这些步骤假设您正在为Windows开发VisualStudio 2017的应用程序。

安装和设置Dotfuscator

首先,你需要在你的开发机上安装Dotfuscator。之后我们将使用Dotfuscator的命令行接口,您还需要注册您的副本并记录到接口的路径。

安装和设置Dotfuscator:

  1. 访问 面,它在优先解决网站。
  2. 下载Visual Studio 2017最新的Dotfuscator 社区版 (CE)
    • Visual Studio包含了 Dotfuscator,P优先解决偶尔发布重要更新将Visual Studio版本之间。 安装Dotfuscator方法是确认你已经更新到最新版本。
  3. 遵照指示运行你下载的VSIX 文件。
  4. 打开Visual Studio 2017并选择 Tools -> PreEmptive Protection – Dotfuscator 来加载Dotfuscator社区版用户接口。
  5. 在你使用命令行接口之前首先要注册Dotfuscator的一个拷贝。在你第一次运行时也被要求注册Dotfuscator;按照指示。
    •   或者检查你的注册状态,查找 注册状态 文本,在Dotfuscator社区版的开始页的右上角。
  6. 你要知道命令行接口的路径,以方便以后配置集成构建。找到路径:
    • 浏览你安装Visual Studio 2017的路径。比如Visual Studio 2017 专业版的默认安装路径是 C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional。
    • 在这个路径中,定位 Dotfuscator 社区版扩展文件,它在 *\Common7\IDE\Extensions\PreEmptiveSolutions\DotfuscatorCE。
    • dotfuscatorCLI.exe是Dotfuscator 社区版命令行接口,记下可执行文件 的绝对路径,以后会用到。

下载构建集成文件

简化集成过程,Dotfuscator组创建了MSBuild目标文件,你可以参考Xamarin项目。

保存PreEmptive.Dotfuscator.Xamarin.targets 文件到你的解决方案路径,并受控。

修改项目使用集成构建

下一步,修改想要混淆的Visual Studio项目的项目文件。步骤如下:

  1. 注意你想要保护的项目的 构建配置。 通常这些都是除了Debug配置之外的所有配置。查看更多指导,请参阅
  2. 在文本编辑器中打开项目文件。一个 C#的样例项目将是`YourProjectName.csproj`。
  3. 请注意从该文件到您下载的构建集成文件的相对路径。
  4. 通过在文件中添加以下行导入构建集成文件, 在 标签之后:
    • ,使用步骤3中提到的绝对路径。
  5. 标签之下,没有条件属性,并添加下面的标签:
    • C:\pathto\dotfuscatorCLI.exe, 用绝对路径替代你之前记录的Dotfuscator社区版命令行接口。
    • DotfuscatorConfig.xml
    • true
  6. 在步骤1中提到的每个构建配置,定位到 并添加下面的标签:
    • true
  7. 在最后的 标签之后,加入下面的内容:
  8. 保存并关闭这个文件。

构建应用程序

现在你可以使用Dotfuscator的混淆保护来构建你的应用程序。这样做:

  1. 在Visual Studio中打开并重新加载你的项目。
  2. 选择一个解决方案生成配置,以执行您决定保护的项目构建配置。
  3. 构建这个项目。
  4. 在第一次构建之后,注意建立输出包含以下几行关于Dotfuscator:
  1. 注意添加一个DotfuscatorConfig.xml文件到你的工程中。它是Dotfuscator配置文件,告诉Dotfuscator如何混淆代码。建议查看源代码控制。
  2. 在文件系统中,注意新的DotfuscatorReports路径会出面在你的项目路径中。这个路径包含了项目如何被混淆的信息,包括了如何逆向和重命名处理。您应该像构建输出那样对待该目录,并拥有源代码管理器忽略它。
  3. 测试应用程序,如果看到错误,需要配置Dotfuscator further进一步确定正确的保护行为。请参见下一节以供参考。
  4. 继续开发应用,像平常一样构建。当Dotfuscator 用于构建,构建输出会包含如下几行:

有关使用混淆继续开发的更多信息, 请查看Dotfuscator 用户指南的 持续发展 一节。

配置重命名

在某些情况下,应用程序假定编译时代码元素的名称在运行时是相同的。这是特别真实的Xamarin程序,依靠XAML和反射。重命名混淆可以打破这个假设,造成混淆的应用程序有不同的表现。

而新的版本将能够更好的自动处理这些场景,某些情况下,可能需要手动配置。用于说明和示例,请查看Dotfuscator用户指南的 页。

高级的混淆

而不是免费的Dotfuscator大众版,你也可以使用 混淆你的Xamarin应用。 专业版是许可用于商业产品,并且

查看社区版和专业版的差别,考虑早期的游戏示例。如果开发者通过Dotfuscator专业版代表社区版来保护库,逆向工程的结果看起来更像:

除了重命名混淆,此代码现在也通过控制流混淆保护。原始代码的语句分散在钝角的“开关”块中 以看似随机的顺序, 使它很难跟随。这些和都是Dotfuscator专业版特有的。

总结

在这篇博客中,我们看到了如何使用Dotfuscator来保护Xamarin库和应用程序,使之不容易被逆向工程。我使用了一个Android应用程序来做例子,这些步骤同样适用于iOS和UWP项目,While I used an Android app as an example, these same steps can also be applied to iOS and UWP projects,所以你可以保护你的应用程序,不管它运行在什么平台上。

如何使用Dotfuscator保护Xamarin工程的更多信息,可以查阅 这里有所有平台的集成Dotfuscator到一个Xamarin工程的git仓库。

你也可以通过访问 优先解决方案博客来获取混淆空间的最新开发草席, 也可以在 跟随优先解决。

阅读(3214) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~