1.生成R文件
d:\>aapt package -f -m -J ./gen -S res -M AndroidManifest.xml -I ..\android.jar
-f 如果编译生成的文件已经存在,强制覆盖。
-m 使生成的包的目录存放在-J参数指定的目录
-J 指定生成的R.java 的输出目录路径
-S 指定res文件夹的路径
-I 指定某个版本平台的android.jar文件的路径
-A 指定assert文件夹的路径
2.生成class文件
d:\> javac -target 1.5 -bootclasspath ..\android.jar -d bin src\com\example\test\*.java gen\com\example\test\R.java
-target <版本> 生成特定 VM 版本的类文件
-bootclasspath <路径> 覆盖引导类文件的位置
-d <目录> 指定存放生成的类文件的位置
-sourcepath <路径> 指定查找输入源文件的位置
3.有class文件生成dex文件
d:\>dx --dex --output=..\bin\classes.dex ..\bin
--output=<要生成的classes.dex路径> <要处理的class文件的路径>
(3也可以class文件先打成jar包,然后在生成dex文件 如:
3.1 打jar包
cd bin
jar cvf hello.jar *
3.2.生成dex文件
cd ..
dx --dex --output=bin\classes.dex bin\hello.jar
)
4. 打包资源
d:\>aapt package -f -M AndroidManifest.xml -S res -I ..\android.jar -F bin\resources.ap_
-f 如果编译生成的文件已经存在,强制覆盖
-M 指定AndroidManifest.xml的路径
-S 指定res文件夹路径
-I 指定某个版本平台的android.jar的路径
-F 指定输出文件完整路径
5.生成未签名apk包 此包不可安装:
d:\>java -cp ..\sdk\tools\lib\sdklib.jar com.android.sdklib.build.ApkBuilderMain bin\test.apk -v -u -z bin\resources.ap_ -f bin\classes.dex -rf src
-v Verbose 显示过程信息
-u 创建一个无签名的包
-z 指定apk资源路径
-f 指定dex文件路径
-rf 指定源码路径
6.生成签名包
d:\>keytool -genkey -alias release -keyalg RSA -validity 20000 -keystore release.keystore
-genkey 在用户主目录中创建一个默认文件".keystore",还会产生一个mykey的别名,mykey中包含用户的公钥、私钥和证书
-alias 产生别名
-keyalg 指定密钥的算法
-validity 指定创建的证书有效期多少天
-keystore 指定密钥库的名称(产生的各类信息将不在.keystore文件中)
7.签名apk文件(此文件可以直接安装)
d:\>jarsigner -verbose -keystore d:\release.keystore -storepass antmima -keypass antmima -signedjar D:\android\test\bin\test-signed.apk ..\bin\test.apk release
-verbose 签名/验证时输出详细信息
-keystore 密钥库位置
-storepass 用于密钥库完整性的口令
-keypass 专用密钥的口令(如果不同)
-signedjar 已签名的 JAR 文件的名称 (第一个apk是签名之后的文件, 第二个apk是需要签名的文件)
8.安装apk到手机
d:\\bin>adb install bin\test-signed.apk