1. 生成R文件
> aapt package -f -m -J ./gen -S res -M AndroidManifest.xml -I D:\android.jar
-f 如果編譯生成的文件已經存在,強制覆蓋。
-m 使生成的包的目錄存放在-J參數指定的目錄
-J 指定生成的R.java 的輸出目錄路徑
-S 指定res文件夾的路徑
-I 指定某個版本平臺的android.jar文件的路徑
-A 指定assert文件夾的路徑
2. Java代碼生成class文件
> javac -target 1.5 -bootclasspath D:\android-sdk-windows\platforms\android-8\android.jar -d bin src\demo\project\*.java gen\demo\project\R.java
-target 生成特定 VM 版本的類文件
-bootclasspath 覆蓋引導類文件的位置
-d 指定存放生成的類文件的位置
-sourcepath 指定查找輸入源文件的位置
3. class文件生成dex文件
dx --dex --output=D:\ProjectDemo\bin\classes.dex D:\ProjectDemo\bin
--output=
4. 打包資源
> aapt package -f -M AndroidManifest.xml -S res -I D:\android-sdk-windows\platforms\android-8\android.jar -F bin\resources.ap_
-f 如果編譯生成的文件已經存在,強制覆蓋
-M 指定AndroidManifest.xml的路徑
-S 指定res文件夾路徑
-I 指定某個版本平臺的android.jar的路徑
-F 指定輸出文件完整路徑
5. 生成apk
apkbuilder D:\ProjectDemo\bin\projectdemo.apk -v -u -z D:\ProjectDemo\bin\resources.ap_ -f D:\ProjectDemo\bin\classes.dex -rf D:\ProjectDemo\src
-v Verbose 顯示過程信息
-u 創建一個無簽名的包
-z 指定apk資源路徑
-f 指定dex文件路徑
-rf 指定源碼路徑
6. 創建密匙
>keytool -genkey -alias release -keyalg RSA -validity 20000 -keystore release.keystore
-genkey 在用戶主目錄中創建一個默認文件".keystore",還會產生一個mykey的別名,mykey中包含用戶的公鑰、私鑰和證書
-alias 產生別名
-keyalg 指定密鑰的算法
-validity 指定創建的證書有效期多少天
-keystore 指定密鑰庫的名稱(產生的各類信息將不在.keystore文件中)
7. 簽名apk
jarsigner -verbose -keystore C:\Users\UserName\Desktop\build\release.keystore -storepass antmima -keypass antmima -signedjar D:\ProjectDemo\bin\projectdemo-signed.apk D:\ProjectDemo\bin\projectdemo.apk release
-verbose 簽名/驗證時輸出詳細信息
-keystore 密鑰庫位置
-storepass 用于密鑰庫完整性的口令
-keypass 專用密鑰的口令(如果不同)
-signedjar 已簽名的 JAR 文件的名稱 (第一個apk是簽名之后的文件, 第二個apk是需要簽名的文件)