ant+proguard签名打包 .jar


 

ant+proguard签名打包 .jar

摘自: https://blog.csdn.net/a_ycmbc/article/details/53432812

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a_ycmbc/article/details/53432812

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

 

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


大致的流程就是选择需要打包的java文件,export执行打包成一个.jar文件
然后通过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执行需要一个build文件,此次项目用到的build文件配置

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project
  3. name="ProjectName"
  4. basedir="."
  5. default="optimize_class" >
  6. <!-- 设置全局属性 -->
  7. <property file="project.properties" />
  8. <property environment="env" />
  9. <property name="encode" value="utf-8"/>
  10. <property name="debug" value="false"/>
  11. <property name="includeAntRuntime" value="false"/>
  12. <property name="target_version" value="1.7"/>
  13. <property name="src_dir" value="${basedir}\src"/>
  14. <!--
  15. ========================================
  16. 工程构建目录
  17. ========================================
  18. -->
  19. <property name="build_dir" value="${basedir}\build" />
  20. <property name="java_build_dir" value="${build_dir}\java" />
  21. <property name="class_build_dir" value="${build_dir}\class" />
  22. <property name="jar_build_dir" value="${build_dir}\jar"/>
  23. <property name="unOptimize_jar_build_dir" value="${jar_build_dir}\unOptimize.jar"/>
  24. <!--
  25. ========================================
  26. 构建完成文件
  27. ========================================
  28. -->
  29. <property name="release_jar_dir" value="${basedir}\${releaseJar}"/>
  30. <!-- 声明第三方依赖的jar -->
  31. <path id="dependencies">
  32. <fileset dir="${basedir}\libs">
  33. <include name="**/*.jar" />
  34. </fileset>
  35. </path>
  36. <!-- 引入Android依赖 -->
  37. <property
  38. name="lib.android"
  39. value="${sdk.dir}\platforms\${target}\android.jar" />
  40. <!-- 引入混淆依赖 -->
  41. <property
  42. name="lib.proguard"
  43. value="E:\adt-bundle-windows-x86_64-20140702\sdk\tools\proguard\lib\proguard.jar" />
  44. <!-- dx命令(当前系统为windows,如果系统为linux,可将.bat文件替换成相对应的命令) -->
  45. <property
  46. name="dx"
  47. value="${sdk.dir}\build-tools\24.0.1\dx.bat" />
  48. <!-- 拆分java文件-->
  49. <target name="init">
  50. <mkdir dir="${build_dir}" />
  51. <mkdir dir="${java_build_dir}" />
  52. <mkdir dir="${class_build_dir}" />
  53. <mkdir dir="${jar_build_dir}" />
  54. </target>
  55. <!-- 拆分java文件 -->
  56. <target name="separate_java" depends="init">
  57. <copy todir="${java_build_dir}" >
  58. <fileset dir="${src_dir}" >
  59. <include name="com/project/package/*.java" />
  60. </fileset>
  61. </copy>
  62. </target>
  63. <!-- 编译java文件 -->
  64. <target name="compile_java" depends="separate_java" >
  65. <javac
  66. bootclasspath="${lib.android}"
  67. debug="${debug}"
  68. destdir="${class_build_dir}"
  69. encoding="${encode}"
  70. includeAntRuntime="${includeAntRuntime}"
  71. srcdir="${java_build_dir}"
  72. target="${target_version}">
  73. <classpath refid="dependencies" />
  74. </javac>
  75. </target>
  76. <!-- 混淆class文件 -->
  77. <target
  78. name="optimize_class"
  79. depends="compile_java" >
  80. <!-- class文件生成jar包 -->
  81. <jar destfile="${unOptimize_jar_build_dir}" >
  82. <fileset
  83. dir="${class_build_dir}"
  84. includes="**/*.class" />
  85. </jar>
  86. <!-- jar包进行混淆 -->
  87. <java
  88. failonerror="true"
  89. fork="true"
  90. jar="${lib.proguard}" >
  91. <jvmarg value="-Dmaximum.inlined.code.length=32" />
  92. <arg value="-injars ${unOptimize_jar_build_dir}"/>
  93. <arg value="-outjars ${release_jar_dir}"/>
  94. <arg value="-libraryjars ${lib.android}"/>
  95. <arg value="-dontpreverify"/>
  96. <arg value="-dontoptimize"/>
  97. <arg value="-dontusemixedcaseclassnames"/>
  98. <arg value="-allowaccessmodification"/>
  99. <arg value="-optimizationpasses 7"/>
  100. <arg value="-verbose"/>
  101. <arg value="-dontskipnonpubliclibraryclasses"/>
  102. <arg value="-dontskipnonpubliclibraryclassmembers"/>
  103. <arg value="@${proguard.cfg}"/>
  104. </java>
  105. <!-- 删除构建目录 -->
  106. <delete dir="${build_dir}"/>
  107. </target>
  108. </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. # Project target.
  13. sdk.dir=E:\\adt-bundle-windows-x86_64-20140702\\sdk
  14. target=android-17
  15. android.library=false
  16. proguard.cfg=proguard.cfg
  17. 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. -optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
  9. -dump proguard/class_files.txt
  10. -printseeds proguard/seeds.txt
  11. -printusage proguard/unused.txt
  12. -printmapping proguard/mapping.txt
  13. -keep public class * extends android.app.Activity
  14. -keep public class * extends android.app.Application
  15. -keep public class * extends android.app.Service
  16. -keep public class * extends android.content.BroadcastReceiver
  17. -keep public class * extends android.content.ContentProvider
  18. -keep public class * extends android.app.backup.BackupAgentHelper
  19. -keep public class * extends android.preference.Preference
  20. -keep public class com.android.vending.licensing.ILicensingService
  21. -keep public class com.gn.qiaw.mn.Entry {
  22. public static <methods>;
  23. }
  24. -keep public class com.gn.qiaw.mn.PayCallBack {
  25. public <methods>;
  26. }
  27. -keepclasseswithmembernames class * {
  28. native <methods>;
  29. }
  30. -keepclasseswithmembers class * {
  31. public <init>(android.content.Context, android.util.AttributeSet);
  32. }
  33. -keepclasseswithmembers class * {
  34. public <init>(android.content.Context, android.util.AttributeSet, int);
  35. }
  36. -keepclassmembers class * extends android.app.Activity {
  37. public void *(android.view.View);
  38. }
  39. -keepclassmembers enum * {
  40. public static **[] values();
  41. public static ** valueOf(java.lang.String);
  42. }
  43. -keep class * implements android.os.Parcelable {
  44. public static final android.os.Parcelable$Creator *;
  45. }
     
        最后,添加proguard文件夹,拷入需要引用的文件proguard.jar,proguardgui.jar,retrace.jar
整个项目的文件目录为:
准备工作做完了,开始执行build文件,打开cmd命令,输入ant -f build.xml,开始执行
执行成功显示BUILD SUCCESSFUL
刷新项目,项目根目录就会出现刚刚要输入的output.jar。
用反编译工具 gd-gui 打开刚刚的文件查看是否混淆成功
可以看到,除了我们在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

 

posted @ 2018-09-17 13:34  LiuYanYGZ  阅读(446)  评论(0编辑  收藏  举报