近期由于工作须要,学习到了Android jar包的打包与混淆。

之前觉得还是非常easy的,可是自己深入研究下,发现还是有一些东西须要注意的,并且自己也踩了一些坑,在这里写下供同僚们借鉴借鉴。

怎样打包

这里我以eclipse 打包为演示样例,假设有朋友是用Andorid Studio开发的话。恕我有点out了。

  1. 选择你的项目,右键–>Export
    在Eclipse上打包并使用Proguard工具混淆jar包_反编译
  2. 选择JAVA分类项–>JAR file –> Next
    在Eclipse上打包并使用Proguard工具混淆jar包_android_02
  3. 这里我们看到的是jar 包生成选项。这里我所须要的是生成第三方sdk jar包供他人使用,所以我这里仅仅须要生成src 目录下的编译好的class 文件就可以。
    在Eclipse上打包并使用Proguard工具混淆jar包_android_03

如图,通常res目录是不一并打包的,提供给第三方的时候,会对应地把res资源给到对方。并导入到对方的项目project中。

假设你的assets目录下有资源,须要勾选上一并打包。至于libs 库,可选也可不选。选择的话,jar大小会大一点,而这里我是没有勾选的,由于我之后会将全部jar 包都统一合并为一个jar 包。这样也会方便第三方的接入,不用那么麻烦地去导入多个jar包。最后选择我们的jar生成路径就可以。

在Eclipse上打包并使用Proguard工具混淆jar包_反编译_04

4. 最后选择好选项。我们点击finish button。看到例如以下图所看到的。那么我们的jar 包就生成成功了。

在Eclipse上打包并使用Proguard工具混淆jar包_jar包_05

混淆

在做混淆之前,我们须要了解。为什么要做混淆。

这里我參考了下郭霖大神的博客,有兴趣了解下的朋友能够先看看。

郭神的博客我简要概述下就是。我们生成的jar包以及apk 文件事实上是并不安全的(详细可參考未做加密的潜蜻蜓FM事件),通过反编译方面的知识,包含反编译代码、反编译资源。我们能够得到开发人员的源代码,甚至是又一次打包,篡改开发人员的文件而达到某种目的。

使用Proguard工具混淆jar包

谷歌非常人性化地为我们提供了一个混淆工具,我们能够在sdk–>tools–>proguard–>bin–>proguardgui 路径下找到它,打开例如以下图。

在Eclipse上打包并使用Proguard工具混淆jar包_反编译_06

这里便是proguard混淆工具,看到右下角有一个Load configuration button,事实上它的本质还是通过proguard-android 文件来进行配置混淆选项的,proguard-android 文件我们能够在sdk–>tools–>proguard–>proguard-android.txt 下找到它,通过配置。我们便能够拥有自己的一份混淆配置文件了。

接下来我们点击左栏的Input/Output button。进入下一步。

这里我们看到上栏,是配置将要混淆的jar 文件以及混淆之后的文件生成路径,我们能够在右栏进行配置。

下栏是我们要进行混淆的project生成的jar文件的其它依赖jar包。

路径都是我本机的,我们看到最后2个jar包比較关键。第一个是你project开发api 的 android.jar 包,路径如图,第二个java 的 rt.jar 包,路径依如图。

这里我坑了一下。由于我自己安装的1.8 的jdk。可是我使用我本机的 rt.jar 包却混淆失败了,会报错例如以下:ProGuard says Unsupported class version number [52.0] (maximum 51.0, Java 1.7) with sbt-proguard。

原因在于proguard 仅仅能支持最高1.7 版本号的jdk, 所以这里我就坑了。之后是找朋友拿了1.7版本号的该jar 包,最后才混淆成功。

在Eclipse上打包并使用Proguard工具混淆jar包_android_07

接下来我们点击next button进入下一步,进入Shrinking 选项,记得要将Shrink选项钩掉。由于我们这个Jar包是独立存在的。没有不论什么项目引用,假设钩中Shrink选项的话就会觉得我们全部的代码都是没用的,从而把全部代码全压缩掉。导出一个空的Jar包。

在Eclipse上打包并使用Proguard工具混淆jar包_android_08

继续点击Next进入Obfuscation界面,在这里能够加入一些混淆的逻辑。和混淆APK时不同的是。这里并不会自己主动帮我们排除混淆四大组件,因此必须要手动声明一下才行。以及我们能够加入我们一些自己定义不混淆的类或者变量。如1所看到的。即我所自己定义的混淆规则,2即是addbutton,点击它,将出现3界面,我们就可以在其上编写排除逻辑。

在Eclipse上打包并使用Proguard工具混淆jar包_jar包_09

假设我们这里要混淆Activity 类。例如以下所看到的。最后记得按OK保存。

在Eclipse上打包并使用Proguard工具混淆jar包_javascript_10

下图是我最后混淆的结果。假设我们不混淆某个类的方法以及变量,即參照1 混淆规则,假设我们不混淆某个包下的全部类的方法以及变量,參照2的混淆规则。

在Eclipse上打包并使用Proguard工具混淆jar包_android_11

继续点击Next进入Optimiazation界面,不用改动不论什么东西,由于我们本身就不启用Optimization功能。

继续点击Next进入Information界面。也不用改动不论什么东西,由于我们也不启用Preverification功能。

接着点击Next,进入Process界面,在这里能够通过点击View configurationbutton来预览一下眼下我们的混淆配置文件。

我们亦可点击Save configuration button,来保存一份我们自己的混淆配置文件。

最后点击Process! button。就可以開始进行混淆了。

在Eclipse上打包并使用Proguard工具混淆jar包_jar包_12

最后当我们看到Success!

就说明我们混淆成功了!

假设有warning 提示。那么即依照提示做对应的改动吧。希望这篇博文能对各位起到一点微小的帮助。