一、搭建搭建環境
1. 安裝JDK 和 Android SDK
2. 配置環境變量 D:\android-sdk-windows\tools C:\Program Files\Java\jdk1.6.0_20\bin
3. 例子信息 項目目錄:D:\ProjectDemo SDK目錄 :D:\android-sdk-windows\platforms\android-8\
二、命令行編譯Android項目
3. 例子信息 項目目錄:D:\ProjectDemo SDK目錄 :D:\android-sdk-windows\platforms\android-8\
二、命令行編譯Android項目
1. 生成R文件
2. Java代碼生成class文件
3. class文件生成dex文件
4. 打包資源
5. 生成apk
6. 創建密匙
7. 簽名apk
1. aapt命令, 生成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. javac命令,生成class文件
3. dx 命令,把class文件轉換為.dex文件
4. aapt命令,打包資源
> 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. dx 命令,把class文件轉換為.dex文件
> dx --dex --output=D:\ProjectDemo\bin\classes.dex D:\ProjectDemo\bin--output=<要生成的classes.dex路徑> <要處理的class文件的路徑>
4. aapt命令,打包資源
> 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. apkbuilder命令,生成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. 創建密鑰
7. 簽名
>keytool -genkey -alias release -keyalg RSA -validity 20000 -keystore release.keystore-genkey 在用戶主目錄中創建一個默認文件".keystore",還會產生一個mykey的別名,mykey中包含用戶的公鑰、私鑰和證書 -alias 產生別名 -keyalg 指定密鑰的算法 -validity 指定創建的證書有效期多少天 -keystore 指定密鑰庫的名稱(產生的各類信息將不在.keystore文件中)
7. 簽名
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是需要簽名的文件)