转载地址:http://blog.csdn.net/liuhe688/article/details/6679879
和http://sunrrycao.blog.163.com/blog/static/200053332201271011122490/
大家好,今天来分享一下如何使用ANT打包Android应用。
通常我们习惯用eclipse来开发Android程序,它会自动帮我们打包当前的应用程序。如果在Navigator视图下,我们可以看到以下几个文件:
在上图中,com包放置的是我们的class文件,classes.dex是class文件经过转换后的可以在dalvik上跑的精简类文件,resources.ap_是经过打包的资源文件,ant.apk就是最终的打包文件。
使用ANT来对应用打包,一般会经过以下几个步骤:
1.用aapt命令生成R.java文件
2.用aidl命令生成相应java文件
3.用javac命令编译java源文件生成class文件
4.用dx.bat将class文件转换成classes.dex文件
5.用aapt命令生成资源包文件resources.ap_
6.用apkbuilder.bat打包资源和classes.dex文件,生成unsigned.apk
7.用jarsinger命令对apk认证,生成signed.apk
为了便于理解和记忆,下面来用一张流程图来说明以上的几个过程:
以上就是整体的流程,下面我们就对其每个部分进行做出详细讲解,把每一个步骤都弄清楚了。
我们需要先熟悉一下每一个步骤所使用到的命令:
1.aapt(Android Asset Packaging Tool)命令,根据资源文件生成R.java文件
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ aapt p -f -m -J ./gen -S res -M AndroidManifest.xml
-I ~/software/android-sdk-linux/platforms/android-19/android.jar
参数说明:
-f 强制覆盖已存在的文件。
-m 在-J指定的位置下自动生成相应的包的目录。
-J 指定R.java文件生成的目录。
-S 指定资源目录。
-M 指定清单文件。
-I 引入类库。
注意,我们当前所在的位置是adjacent-fragment-pager-sample项目根目录,所以必要时需要输入很多关于命令的路径,以下示例也是一样。
aapt所在目录:
/home/wsl/software/android-sdk-linux/build-tools/18.0.1/aapt
2.aidl(Android Interface Definition Language)命令,根据.aidl定义文件生成java文件
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ aidl src/main/java/com/jakewharton/example/test.aidl
gen/com/jakewharton/example/adjacent/test.java
PS:2个参数path分别代表aidl以及生成的java文件的路径
3.javac(Java Compiler)命令,根据源文件生成对应的class文件
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ javac -encoding utf-8 -target 1.6
-d bin src/main/java/com/jakewharton/example/*.java gen/com/jakewharton/example/adjacent/R.java
-bootclasspath ~/software/android-sdk-linux/platforms/android-19/android.jar
-classpath libs/android-support-v4.jar
ps:这里用到了android-support-v4.jar,加上-classpath指定jar的位置
其中,可能的选项包括:
-g 生成所有调试信息
-g:none 不生成任何调试信息
-g:{lines,vars,source} 只生成某些调试信息
-nowarn 不生成任何警告
-verbose 输出有关编译器正在执行的操作的消息
-deprecation 输出使用已过时的 API 的源位置
-classpath <路径> 指定查找用户类文件和注释处理程序的位置
-cp <路径> 指定查找用户类文件和注释处理程序的位置
-sourcepath <路径> 指定查找输入源文件的位置
-bootclasspath <路径> 覆盖引导类文件的位置
-extdirs <目录> 覆盖安装的扩展目录的位置
-endorseddirs <目录> 覆盖签名的标准路径的位置
-proc:{none,only} 控制是否执行注释处理和/或编译。
-processor <class1>[,<class2>,<class3>...]要运行的注释处理程序的名称;绕过默认
的搜索进程
-processorpath <路径> 指定查找注释处理程序的位置
-d <目录> 指定存放生成的类文件的位置
-s <目录> 指定存放生成的源文件的位置
-implicit:{none,class} 指定是否为隐式引用文件生成类文件
-encoding <编码> 指定源文件使用的字符编码
-source <版本> 提供与指定版本的源兼容性
-target <版本> 生成特定 VM 版本的类文件
-version 版本信息
-help 输出标准选项的提要
-Akey[=value] 传递给注释处理程序的选项
-X 输出非标准选项的提要
-J<标志> 直接将 <标志> 传递给运行时系统
4.dx命令,将class文件转换成.dex文件
将工程bin目录下的class文件编译成classes.dex,Android虚拟机只能执行dex文件!
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ dx --dex --output=bin/classes.dex bin
5.aapt将资源文件打包
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ aapt p -f -M AndroidManifest.xml -S res/ -A assets
-I ~/software/android-sdk-linux/platforms/android-19/android.jar -F bin/resources.ap_
参数说明:
-f 强制覆盖
-M 指定Manifest文件
-S 指定资源目录
-A 指定资产目录
-I 指定引入的类库
-F 指定要生成的包
6.apkbuilder命令,根据classes.dex文件和resources.ap_生成为签证的apk包
重要参数如下:
-v Verbose.
-d Debug Mode: Includes debug files in the APK file.
-u Creates an unsigned package.
-storetype Forces the KeyStore type. If ommited the default is used.
-z Followed by the path to a zip archive.
Adds the content of the application package.
-f Followed by the path to a file.
Adds the file to the application package.
-rf Followed by the path to a source folder.
Adds the java resources found in that folder to the application
package, while keeping their path relative to the source folder.
-rj Followed by the path to a jar file or a folder containing
jar files.
Adds the java resources found in the jar file(s) to the application
package.
-nf Followed by the root folder containing native libraries to
include in the application package.
注:1,如果需要将so文件打包进apk,一定要加上-nf参数
2,如果第三方jar包里含有图片资源,一定要加上-rj参数,不然jar包里资源文件解不出来,程序会因为无法引用资源而报错!
-A 指定资产目录
-I 指定引入的类库
-F 指定要生成的包
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ apkbuilder bin/test_unsign.apk -v -u -z bin/resources.ap_
-f bin/classes.dex -rf src -nf libs -rj libs
7.jarsigner命令,对上面生成的apk包进行签证
jarsigner参数如下:
[-keystore <url>] 密钥库位置
[-storepass <口令>] 用于密钥库完整性的口令
[-storetype <类型>] 密钥库类型
[-keypass <口令>] 专用密钥的口令(如果不同)
[-sigfile <文件>] .SF/.DSA 文件的名称
[-signedjar <文件>] 已签名的 JAR 文件的名称
[-digestalg <算法>] 摘要算法的名称
[-sigalg <算法>] 签名算法的名称
[-verify] 验证已签名的 JAR 文件
[-verbose] 签名/验证时输出详细信息
[-certs] 输出详细信息和验证时显示证书
[-tsa <url>] 时间戳机构的位置
[-tsacert <别名>] 时间戳机构的公共密钥证书
[-altsigner <类>] 替代的签名机制的类名
[-altsignerpath <路径列表>] 替代的签名机制的位置
[-internalsf] 在签名块内包含 .SF 文件
[-sectionsonly] 不计算整个清单的散列
[-protected] 密钥库已保护验证路径
[-providerName <名称>] 提供者名称
[-providerClass <类> 加密服务提供者的名称
[-providerArg <参数>]] ... 主类文件和构造函数参数
首先利用java sdk的keytool生成release证书
keytool -genkey -alias release -keyalg RSA -validity 1000 -keystore release.keystore -dname "CN=w,OU=w,O=localhost,L=w,ST=w,C=CN" -keypass 123456 -storepass 123456
然后对上一步生存的未签名证书签名
wsl@wsl-OptiPlex-7010:~/temp/adjacent-fragment-pager-sample$ jarsigner -keystore release.keystore -storepass 111111 -keypass 111111
-signedjar bin/test2.apk bin/test_unsign.apk release
在签证的过程中,需要使用到证书文件,需要注意的是最后的release是证书的别名,也就是创建证书时alias参数指定的值