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

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

现在,Xamarin的开发商获得同样的保护,在所有主要的移动设备的家庭,将Android和iOS移植到通用的Windows(UWP)。完成这个工作 的工具叫做 Dotfuscator, 社区版本 在 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。

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

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

安装和设置Dotfuscator

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

安装和设置Dotfuscator:

  1. 访问 Dotfuscator 下载 面,它在优先解决网站。

  2. 下载Visual Studio 2017最新的Dotfuscator 社区版 (CE)

  • Visual Studio包含了 Dotfuscator,P优先解决偶尔发布重要更新将Visual Studio版本之间。 安装Dotfuscator方法是确认你已经更新到最新版本。

遵照指示运行你下载的VSIX 文件。 打开Visual Studio 2017并选择 Tools -> PreEmptive Protection – Dotfuscator 来加载Dotfuscator社区版用户接口。 在你使用命令行接口之前首先要注册Dotfuscator的一个拷贝。在你第一次运行时也被要求注册Dotfuscator;按照指示。

  • 注册以后 或者检查你的注册状态,查找 注册状态 文本,在Dotfuscator社区版的开始页的右上角。

你要知道命令行接口的路径,以方便以后配置集成构建。找到路径:

  • dotfuscatorCLI.exe是Dotfuscator 社区版命令行接口,记下可执行文件 的绝对路径,以后会用到。

  • 在这个路径中,定位 Dotfuscator 社区版扩展文件,它在 *\Common7\IDE\Extensions\PreEmptiveSolutions\DotfuscatorCE。

  • 浏览你安装Visual Studio 2017的路径。比如Visual Studio 2017 专业版的默认安装路径是 C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional。

下载构建集成文件

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

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

修改项目使用集成构建

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

  1. 注意你想要保护的项目的 构建配置。 通常这些都是除了Debug配置之外的所有配置。查看更多指导,请参阅从完全文档中选择如何保护一节。

  2. 在文本编辑器中打开项目文件。一个 C#的样例项目将是`YourProjectName.csproj`。

  3. 请注意从该文件到您下载的构建集成文件的相对路径。

  4. 通过在文件中添加以下行导入构建集成文件, 在</Project> 标签之后:

  • <Import Project="..\..\PreEmptive.Dotfuscator.Xamarin.targets" />,使用步骤3中提到的绝对路径。

要<PropertyGroup> 标签之下,没有条件属性,并添加下面的标签:

  • <DotfuscatorXamarinCliPath>C:\pathto\dotfuscatorCLI.exe</DotfuscatorXamarinCliPath>, 用绝对路径替代你之前记录的Dotfuscator社区版命令行接口。

  • <DotfuscatorXamarinConfigFileName>DotfuscatorConfig.xml</DotfuscatorXamarinConfigFileName>

  • <DotfuscatorXamarinGenerateNewConfigFile>true</DotfuscatorXamarinGenerateNewConfigFile>

在步骤1中提到的每个构建配置,定位到 <PropertyGroup>并添加下面的标签:

  • <DotfuscatorXamarinEnabled>true</DotfuscatorXamarinEnabled>

在最后的<ItemGroup> 标签之后,加入下面的内容:

  • <ItemGroup><None Include="DotfuscatorConfig.xml" /></ItemGroup>

保存并关闭这个文件。

构建应用程序

现在你可以使用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大众版,你也可以使用 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页。 这里有所有平台的集成Dotfuscator到一个Xamarin工程的git仓库。

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

转载于:https://blog.51cto.com/3353175/1968666

使用Dotfuscator保护你的Xamarin应用程序相关推荐

  1. 使用这些HTTP标头保护您的Web应用程序

    by Alex Nadalin 通过亚历克斯·纳达林 使用这些HTTP标头保护您的Web应用程序 (Secure your web application with these HTTP header ...

  2. 保护你的 Flutter 应用程序

    保护你的 Flutter 应用程序 原文 https://medium.com/flutter-community/securing-your-flutter-applications-77c2bf3 ...

  3. android 中止应用程序,如何终止Xamarin应用程序?

    如何终止Xamarin应用程序? 如何从任何活动中终止Xamarin应用程序? 我已经尝试了System.Environment.Exit(0)和System.Environment.Exit(1)以 ...

  4. Acunetix 简介 为什么需要保护您的 Web 应用程序

    为什么需要保护您的 Web 应用程序 网站安全是当今保护企业最容易被忽视的方面,应该是任何组织的优先事项.黑客越来越多地将精力集中在基于 Web 的应用程序上--购物车.表单.登录页面.动态内容等. ...

  5. 一起谈.NET技术,保护您的 Silverlight 应用程序的安全

    作为一名 Microsoft 服务顾问,我定期与客户和合作伙伴一起进行应用程序安全性讨论. 在本文中,我将介绍一些在这些讨论中提出的主题. 特别是,我将重点介绍编程人员在尝试保护 Silverligh ...

  6. java 程序增加 防盗_防盗Java EE –保护Java EE企业应用程序的安全

    java 程序增加 防盗 Øredev离我们仅有几天的路程,我受邀作了两次演讲. 其中之一是关于我最喜欢的主题:安全性和Java EE. 它旨在实现两个目标. 一方面向典型的Java EE开发人员介绍 ...

  7. 使用BaaS更快地构建Xamarin应用程序

    目录 问题 什么是MVP? 解决方案 创建RESTful后端 抓取您的帐户名称 抓取您的API密钥 创建一个新项目 获取Android模拟器设置 添加MeshyDB SDK 建立连接 配置客户端 注册 ...

  8. [附源码]计算机毕业设计Python保护濒危动物公益网站(程序+源码+LW文档)

    该项目含有源码.文档.程序.数据库.配套开发软件.软件安装教程 项目运行 环境配置: Pychram社区版+ python3.7.7 + Mysql5.7 + HBuilderX+list pip+N ...

  9. oidc_使用OIDC和Ionic for JHipster保护您的移动应用程序

    oidc "我喜欢编写身份验证和授权代码." 〜从来没有Java开发人员. 厌倦了一次又一次地建立相同的登录屏幕? 尝试使用Okta API进行托管身份验证,授权和多因素身份验证. ...

最新文章

  1. [转]WebPack 常用功能介绍
  2. 计算机组成原理 — ARM 体系结构
  3. 英国伯明翰大学首席教授姚新:人工智能研究应从三个问题重新考虑
  4. 【企业管理】人力资源是CEO的第一工程
  5. JavaFX 2.0布局窗格– GridPane
  6. gcc参数 -i, -L, -l, -include
  7. 60-100-030-使用-Docker MySQL 8 主从复制
  8. [JAVA基础]你知道Java的四种引用类型吗
  9. SpringCloud学习笔记023---SpringBoot集成Dubbo_依赖zookeeper实现分布式应用一致性以及远程服务调用
  10. python写crm_Python CRM项目八
  11. # Please enter the commit message for your changes. Lines starting # with ‘#‘ will be ignored
  12. python怎么显示提示_Python中如何显示程序进度
  13. 【机器学习-西瓜书】九、聚类:性能度量;距离计算
  14. 没车牌也能开上国产特斯拉:北京3年租赁每月1万1,全国最低7千
  15. ISP模块之RAW DATA去噪(一)
  16. 如何下载谷歌地球高程为TIF格式的文件
  17. 重装ubuntu16.04之搜狗拼音输入法
  18. 关于write和read以及文件读写位置
  19. 智能厨房监控系统设计
  20. 靠窗座位订票技能和退票省钱技能

热门文章

  1. encache学习教程
  2. SQL2008R2 express版本不支持维护计划
  3. 虚拟化正是云计算所依托的基石
  4. [转]EOS智能合约 私链激活 基本操作
  5. Cannot set property 'render' of undefined
  6. SQL Server 2005 For XML[学习]
  7. Effective C++ Item 30 inline里里外外
  8. SQL Server 2016 AlwaysOn 安装及配置介绍
  9. 编程问题之:x=xamp;(x-1)
  10. JAVA中的list去重复