ant+proguard签名打包 .jar

 

2016年12月02日 14:52:36 标签: antproguard混淆 更多
个人分类: Android
 
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a_ycmbc/article/details/53432812

很久没有更新了,最近做了个小功能,想把代码打成 .jar文件给别人引用。除了基本的调用方法,其余核心代码都经过混淆打包。用到了ant+proguard,这里记录一下。 

 

ProGuard是一个压缩、优化和混淆Java字节码文件的免费的工具,它可以删除无用的类、字段、方法和属性。可以删除没用的注释,最大限度地优化字节码文件。它还可以使用简短的无意义的名称来重命名已经存在的类、字段、方法和属性。常常用于Android开发用于混淆最终的项目,增加项目被反编译的难度。android的sdk中已经有此工具,在sdk\tools\proguard\lib\proguardgui.jar,打包是可以直接用此工具混淆,只是流程比较复杂,需要手动更改其中的配置。如图:

 

ant+proguard签名打包 .jar_java
大致的流程就是选择需要打包的java文件,export执行打包成一个.jar文件
ant+proguard签名打包 .jar_默认值_02
然后通过proguard一步一步选择,配置就可以混淆打包了。详细步骤及配置就不说了,网上很多例子。
 
 
下面主要讲一下怎样用ant执行build文件来混淆打包。

Ant是Apache软件基金会JAKARTA目录中的一个子项目,它有以下的优点。跨平台性。Ant是纯Java语言编写的,所以具有很好的跨平台性。操作简单。Ant是由一个内置任务和可选任务组成的。Ant运行时需要一个XML文件(构建文件)。 Ant通过调用target树,就可以执行各种task。每个task实现了特定接口对象。由于Ant构建文件 是XML格式的文件,所以很容易维护和书写,而且结构很清晰。Ant可以集成到开发环境中。由于Ant的跨平台性和操作简单的特点,它很容易集成到一些开发环境中去。

安装和配置环境变量

到官方主页http://ant.apache.org下载新版的ant,得到的是一个apache-ant-bin.zip的压缩包。将其解压到你的硬盘上。

window中设置ant环境变量:

       ANT_HOME    C:/ apache-ant-1.8.1

       path             C:/ apache-ant-1.8.1/bin

       classpath      C:/apache-ant-1.8.1/lib

测试是否配置成功

 

ant+proguard签名打包 .jar_jar_03

      

ant执行需要一个build文件,此次项目用到的build文件配置

 

  1.  
    <?xml version="1.0" encoding="UTF-8"?>
  2.  
    <project
  3.  
    name="ProjectName"
  4.  
    basedir="."
  5.  
    default="optimize_class" >
  6.  
     
  7.  
    <!-- 设置全局属性 -->
  8.  
    <property file="project.properties" />
  9.  
     
  10.  
    <property environment="env" />
  11.  
    <property name="encode" value="utf-8"/>
  12.  
    <property name="debug" value="false"/>
  13.  
    <property name="includeAntRuntime" value="false"/>
  14.  
    <property name="target_version" value="1.7"/>
  15.  
    <property name="src_dir" value="${basedir}\src"/>
  16.  
     
  17.  
    <!--
  18.  
    ========================================
  19.  
    工程构建目录
  20.  
    ========================================
  21.  
    -->
  22.  
    <property name="build_dir" value="${basedir}\build" />
  23.  
    <property name="java_build_dir" value="${build_dir}\java" />
  24.  
    <property name="class_build_dir" value="${build_dir}\class" />
  25.  
    <property name="jar_build_dir" value="${build_dir}\jar"/>
  26.  
    <property name="unOptimize_jar_build_dir" value="${jar_build_dir}\unOptimize.jar"/>
  27.  
    <!--
  28.  
    ========================================
  29.  
    构建完成文件
  30.  
    ========================================
  31.  
    -->
  32.  
    <property name="release_jar_dir" value="${basedir}\${releaseJar}"/>
  33.  
     
  34.  
     
  35.  
     
  36.  
    <!-- 声明第三方依赖的jar -->
  37.  
    <path id="dependencies">
  38.  
    <fileset dir="${basedir}\libs">
  39.  
    <include name="**/*.jar" />
  40.  
    </fileset>
  41.  
    </path>
  42.  
     
  43.  
    <!-- 引入Android依赖 -->
  44.  
    <property
  45.  
    name="lib.android"
  46.  
    value="${sdk.dir}\platforms\${target}\android.jar" />
  47.  
     
  48.  
    <!-- 引入混淆依赖 -->
  49.  
    <property
  50.  
    name="lib.proguard"
  51.  
    value="E:\adt-bundle-windows-x86_64-20140702\sdk\tools\proguard\lib\proguard.jar" />
  52.  
    <!-- dx命令(当前系统为windows,如果系统为linux,可将.bat文件替换成相对应的命令) -->
  53.  
    <property
  54.  
    name="dx"
  55.  
    value="${sdk.dir}\build-tools\24.0.1\dx.bat" />
  56.  
     
  57.  
     
  58.  
    <!-- 拆分java文件-->
  59.  
    <target name="init">
  60.  
    <mkdir dir="${build_dir}" />
  61.  
    <mkdir dir="${java_build_dir}" />
  62.  
    <mkdir dir="${class_build_dir}" />
  63.  
    <mkdir dir="${jar_build_dir}" />
  64.  
    </target>
  65.  
     
  66.  
    <!-- 拆分java文件 -->
  67.  
    <target name="separate_java" depends="init">
  68.  
    <copy todir="${java_build_dir}" >
  69.  
    <fileset dir="${src_dir}" >
  70.  
    <include name="com/project/package/*.java" />
  71.  
    </fileset>
  72.  
    </copy>
  73.  
    </target>
  74.  
     
  75.  
    <!-- 编译java文件 -->
  76.  
    <target name="compile_java" depends="separate_java" >
  77.  
    <javac
  78.  
    bootclasspath="${lib.android}"
  79.  
    debug="${debug}"
  80.  
    destdir="${class_build_dir}"
  81.  
    encoding="${encode}"
  82.  
    includeAntRuntime="${includeAntRuntime}"
  83.  
    srcdir="${java_build_dir}"
  84.  
    target="${target_version}">
  85.  
    <classpath refid="dependencies" />
  86.  
    </javac>
  87.  
    </target>
  88.  
     
  89.  
    <!-- 混淆class文件 -->
  90.  
    <target
  91.  
    name="optimize_class"
  92.  
    depends="compile_java" >
  93.  
    <!-- class文件生成jar包 -->
  94.  
    <jar destfile="${unOptimize_jar_build_dir}" >
  95.  
    <fileset
  96.  
    dir="${class_build_dir}"
  97.  
    includes="**/*.class" />
  98.  
    </jar>
  99.  
    <!-- jar包进行混淆 -->
  100.  
    <java
  101.  
    failonerror="true"
  102.  
    fork="true"
  103.  
    jar="${lib.proguard}" >
  104.  
    <jvmarg value="-Dmaximum.inlined.code.length=32" />
  105.  
    <arg value="-injars ${unOptimize_jar_build_dir}"/>
  106.  
    <arg value="-outjars ${release_jar_dir}"/>
  107.  
    <arg value="-libraryjars ${lib.android}"/>
  108.  
     
  109.  
    <arg value="-dontpreverify"/>
  110.  
    <arg value="-dontoptimize"/>
  111.  
    <arg value="-dontusemixedcaseclassnames"/>
  112.  
    <arg value="-allowaccessmodification"/>
  113.  
    <arg value="-optimizationpasses 7"/>
  114.  
    <arg value="-verbose"/>
  115.  
    <arg value="-dontskipnonpubliclibraryclasses"/>
  116.  
    <arg value="-dontskipnonpubliclibraryclassmembers"/>
  117.  
    <arg value="@${proguard.cfg}"/>
  118.  
    </java>
  119.  
    <!-- 删除构建目录 -->
  120.  
    <delete dir="${build_dir}"/>
  121.  
    </target>
  122.  
    </project>

 

常用基本配置不用管,注意其中几个地方:

1. <property file="project.properties" />    指定文件,设置全局属性

2.<property name="encode" value="utf-8"/>    项目的编码格式

3.<property name="target_version" value="1.7"/>     java的jdk版本

4. <include name="com/project/package/*.java" />    需要混淆的java类,这里是将package包下面的所有类都混淆,可以根据自己的项目结构更改此处。

 

 build.xml常用标签说明:

 

 

1.<project>标签
每个构建文件对应一个项目。<project>标签是构建文件的根标签。它可以有多个内在属性, 就如代码中所示,其各个属性的含义分别如下。
(1) default表示默认的运行目标,即指定默认的target(即任务)。这个属性是必须的。
(2) basedir表示项目的基准目录。
(3) name表示项目名。
(4) description表示项目的描述。
2.<target>标签
一个项目标签下可以有一个或多个target标签。一个target标签可以依赖其他的target标签。例 如,有一个target用于编译程序,另一个target用于生成可执行文件。在生成可执行文件之前必须先编译该文件,因此可执行文件的target依赖于编译程序的target。Target的所有属性如下。
(1).name表示目标名,这个属性是必须的。
(2).depends表示依赖的目标。
(3)if表示仅当属性设置时才执行。
(4)unless表示当属性没有设置时才执行。
(5)description表示项目的描述。
Ant的depends属性指定了target的执行顺序。Ant会依照depends属性中target出现顺序依次执行 每个target。在执行之前,首先需要执行它所依赖的target。程序中的名为run的target的 depends属性compile,而名为compile的target的depends属性是prepare,所以这几个target执 行的顺序是prepare->compile->run。一个target只能被执行一次,即使有多个target依赖于它。如果没有if或unless属性target总 会被执行。
3.<mkdir>标签
该标签用于创建一个目录,它有一个属性dir用来指定所创建的目录名,其代码如下:
<mkdir dir=”${class.root}”/>
通过以上代码就创建了一个目录,这个目录已经被前面的property标签所指定。
4<jar>标签
该标签用来生成一个JAR文件,其属性如下。
(1) destfile表示JAR文件名。
(2) basedir表示被归档的文件名。
(3) includes表示被归档的文件模式。
(4) excludes表示被排除的文件模式。
5.<javac标签>
该标签用于编译一个或一组java文件,其属性如下。
(1).srcdir表示源程序的目录。
(2).destdir表示class文件的输出目录。
(3).include表示被编译的文件的模式。
(4).excludes表示被排除的文件的模式。
(5).classpath表示所使用的类路径。
(6).debug表示包含的调试信息。
(7).optimize表示是否使用优化。
(8).verbose 表示提供详细的输出信息。
(9).fileonerror表示当碰到错误就自动停止。
6.<java>标签
该标签用来执行编译生成的.class文件,其属性如下。
(1).classname 表示将执行的类名。
(2).jar表示包含该类的JAR文件名。
(3).classpath所表示用到的类路径。
(4).fork表示在一个新的虚拟机中运行该类。
(5).failonerror表示当出现错误时自动停止。
(6).output 表示输出文件。
(7).append表示追加或者覆盖默认文件。
7.<delete>标签
该标签用于删除一个文件或一组文件,去属性如下。
(1)/file表示要删除的文件。
(2).dir表示要删除的目录。
(3).includeEmptyDirs 表示指定是否要删除空目录,默认值是删除。
(4).failonerror 表示指定当碰到错误是否停止,默认值是自动停止。
(5).verbose表示指定是否列出所删除的文件,默认值为不列出。
8.<copy>标签
该标签用于文件或文件集的拷贝,其属性如下。
(1).file 表示源文件
(2).tofile 表示目标文件。
(3).todir 表示目标目录。
(4).overwrite 表示指定是否覆盖目标文件,默认值是不覆盖。
(5).includeEmptyDirs 表示指定是否拷贝空目录,默认值为拷贝。
(6).failonerror 表示指定如目标没有发现是否自动停止,默认值是停止。
(7).verbose 表示制定是否显示详细信息,默认值不显示。
9.<exec>执行文件:
<execexecutable="${base.dir}/email.bat" >
</exec>
配置project.properties文件

  1.  
    # This file is automatically generated by Android Tools.
  2.  
    # Do not modify this file -- YOUR CHANGES WILL BE ERASED!
  3.  
    #
  4.  
    # This file must be checked in Version Control Systems.
  5.  
    #
  6.  
    # To customize properties used by the Ant build system edit
  7.  
    # "ant.properties", and override values to adapt the script to your
  8.  
    # project structure.
  9.  
    #
  10.  
    # To enable ProGuard to shrink and obfuscate your code, uncomment this (available properties: sdk.dir, user.home):
  11.  
    #proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
  12.  
     
  13.  
    # Project target.
  14.  
    sdk.dir=E:\\adt-bundle-windows-x86_64-20140702\\sdk
  15.  
    target=android-17
  16.  
    android.library=false
  17.  
    proguard.cfg=proguard.cfg
  18.  
    releaseJar=output.jar
       
 sdk.dir是android的sdk目
 releaseJar是输出的jar名字,可以任取
 
       再配置proguard.cfg文件,此文件就是混淆要设置的,哪些类的方法要公开,哪些类的方法要混淆,都是在这里设置
  1.  
    -optimizationpasses 5
  2.  
    -dontusemixedcaseclassnames
  3.  
    -dontskipnonpubliclibraryclasses
  4.  
    -dontpreverify
  5.  
    -dontwarn
  6.  
    -dontnote
  7.  
    -verbose
  8.  
     
  9.  
    -optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
  10.  
     
  11.  
    -dump proguard/class_files.txt
  12.  
    -printseeds proguard/seeds.txt
  13.  
    -printusage proguard/unused.txt
  14.  
    -printmapping proguard/mapping.txt
  15.  
     
  16.  
    -keep public class * extends android.app.Activity
  17.  
    -keep public class * extends android.app.Application
  18.  
    -keep public class * extends android.app.Service
  19.  
    -keep public class * extends android.content.BroadcastReceiver
  20.  
    -keep public class * extends android.content.ContentProvider
  21.  
    -keep public class * extends android.app.backup.BackupAgentHelper
  22.  
    -keep public class * extends android.preference.Preference
  23.  
    -keep public class com.android.vending.licensing.ILicensingService
  24.  
     
  25.  
    -keep public class com.gn.qiaw.mn.Entry {
  26.  
    public static <methods>;
  27.  
    }
  28.  
     
  29.  
    -keep public class com.gn.qiaw.mn.PayCallBack {
  30.  
    public <methods>;
  31.  
    }
  32.  
     
  33.  
    -keepclasseswithmembernames class * {
  34.  
    native <methods>;
  35.  
    }
  36.  
    -keepclasseswithmembers class * {
  37.  
    public <init>(android.content.Context, android.util.AttributeSet);
  38.  
    }
  39.  
    -keepclasseswithmembers class * {
  40.  
    public <init>(android.content.Context, android.util.AttributeSet, int);
  41.  
    }
  42.  
    -keepclassmembers class * extends android.app.Activity {
  43.  
    public void *(android.view.View);
  44.  
    }
  45.  
    -keepclassmembers enum * {
  46.  
    public static **[] values();
  47.  
    public static ** valueOf(java.lang.String);
  48.  
    }
  49.  
    -keep class * implements android.os.Parcelable {
  50.  
    public static final android.os.Parcelable$Creator *;
  51.  
    }
     
        最后,添加proguard文件夹,拷入需要引用的文件proguard.jar,proguardgui.jar,retrace.jar
整个项目的文件目录为:
ant+proguard签名打包 .jar_android_04
 
准备工作做完了,开始执行build文件,打开cmd命令,输入ant -f build.xml,开始执行
ant+proguard签名打包 .jar_android_05
ant+proguard签名打包 .jar_android_06
执行成功显示BUILD SUCCESSFUL。
刷新项目,项目根目录就会出现刚刚要输入的output.jar。
用反编译工具 gd-gui 打开刚刚的文件查看是否混淆成功
ant+proguard签名打包 .jar_java_07
可以看到,除了我们在proguard.cfg设置的两个类没有被混淆,其余的都混淆成功了
  1.  
    -keep public class com.gn.qiaw.mn.Entry {
  2.  
    public static <methods>;
  3.  
    }
  4.  
    -keep public class com.gn.qiaw.mn.PayCallBack {
  5.  
    public <methods>;
  6.  
    }
最后就可以把你的jar给别人用啦!!
jar运行时如果出现了下面这个错误,一般都是jdk运行无法解析某些类,我的jdk版本是1.8的,但是proguard可以尝试将build.xml文件中的<property name="target_version" value="1.7"/> jdk版本改为1.7,就可以运行了。
  1.  
    Dx unsupported class file version 52.0
  2.  
    Conversion to Dalvik format failed with error 1
  3.