Ant 编译源代码生成apk

转载地址: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的位置


javac用法如下:

其中,可能的选项包括:
  -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


-dname以后后面的参数可以通过交互设置,也可直接设定

然后对上一步生存的未签名证书签名

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参数指定的值




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值