如何使用Cordova命令行界面创build签名的APK文件?

这是我第一次在Apache Cordova上工作。 我做了一个名为checkStatus的示例应用程序。 现在我想创build一个签名APK文件。 所以我可以将其安装在不同的设备上进行testing。

为此,我Googlesearch了这个文档 。

根据文档,我切换到我的项目目录并运行以下命令:

 keytool -genkey -v -keystore key-name.keystore -alias alias-name -keyalg RSA -keysize 2048 -validity 10000 

运行上面的命令后,我在projectRoot/key-name.keystore得到一个名为key-name.keystore的文件。

然后我将该文件复制粘贴到projectRoot/platforms/android/key-name.keystore

之后,我创build了一个名为ant.properties的文件,并将其保存在projectRoot/platforms/android

我在文件中写了下面的代码:

 key.store=projectRoot/key-name.keystore key.alias=myApp 

之后,我运行以下命令释放

 Cordova builds android --release 

这是抛出以下错误:

  /home/projectRoot/platforms/android/cordova/node_modules/q/q.js:126 throw e; ^ Error code 1 for command: ant with args: release,-f,/home/projectRoot/platforms/android/build.xml,-Dout.dir=ant-build,-Dgen.absolute.dir=ant-gen Error: /home/projectRoot/platforms/android/cordova/build: Command failed with exit code 8 at ChildProcess.whenDone (/usr/lib/node_modules/cordova/node_modules/cordova-lib/src/cordova/superspawn.js:135:23) at ChildProcess.EventEmitter.emit (events.js:98:17) at maybeClose (child_process.js:753:16) at Process.ChildProcess._handle.onexit (child_process.js:820:5) 

所以这一次,我像下面这样修改了ant.properties文件中的key.store值。

  key.store=/home/projectRoot/platforms/android/key-name.keystore 

再次,我运行了cordova build android --release命令。 它引发同样的错误。

谁能告诉我我做错了什么?

步骤1:

 D:\projects\Phonegap\Example> cordova plugin rm org.apache.cordova.console --save 

添加--save以便从config.xml文件中删除该插件。

第2步:

要为Android生成发布版本,我们首先需要对platform / android中的AndroidManifest.xml文件进行一些小改动。 编辑文件并更改行:

 <application android:debuggable="true" android:hardwareAccelerated="true" android:icon="@drawable/icon" android:label="@string/app_name"> 

并将android:debuggable更改为false

 <application android:debuggable="false" android:hardwareAccelerated="true" android:icon="@drawable/icon" android:label="@string/app_name"> 

从cordova 6.2.0开始,彻底删除android:debuggable标签。 以下是来自cordova的解释:

对“HardcodedDebugMode”types的问题的解释:最好省略清单中的android:debuggable属性。 如果你这样做,那么当构build一个APK在仿真器或设备上debugging时,这些工具会自动插入android:debuggable = true。 当你执行一个发布版本,比如Exporting APK,它会自动将其设置为false。

另一方面,如果您在清单文件中指定了一个特定的值,那么这些工具将始终使用它。 这可能会导致意外地发布您的应用程序debugging信息。

第3步:

现在我们可以告诉cordova产生我们的发布版本:

 D:\projects\Phonegap\Example> cordova build --release android 

然后,我们可以在platforms/android/ant-buildfind我们未签名的APK文件。 在我们的例子中,文件是platforms/android/ant-build/Example-release-unsigned.apk

步骤4:

注意:在这个Git Repo中我们有我们的密钥库keystoreNAME-mobileapps.keystore ,如果你想创build另一个,请继续下面的步骤。

密钥生成:

句法:

 keytool -genkey -v -keystore <keystoreName>.keystore -alias <Keystore AliasName> -keyalg <Key algorithm> -keysize <Key size> -validity <Key Validity in Days> 

EGS:

 keytool -genkey -v -keystore NAME-mobileapps.keystore -alias NAMEmobileapps -keyalg RSA -keysize 2048 -validity 10000 keystore password? : xxxxxxx What is your first and last name? : xxxxxx What is the name of your organizational unit? : xxxxxxxx What is the name of your organization? : xxxxxxxxx What is the name of your City or Locality? : xxxxxxx What is the name of your State or Province? : xxxxx What is the two-letter country code for this unit? : xxx 

然后,密钥存储已经使用NAME-mobileapps.keystore名称生成

第5步:

放置生成的密钥库

旧版本的cordova

 D:\projects\Phonegap\Example\platforms\android\ant-build 

新版本的cordova

 D:\projects\Phonegap\Example\platforms\android\build\outputs\apk 

要签署未签名的APK,请运行也包含在JDK中的jarsigner工具:

句法:

 jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore <keystorename <Unsigned APK file> <Keystore Alias name> 

EGS:

 D:\projects\Phonegap\Example\platforms\android\ant-build> jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore NAME-mobileapps.keystore Example-release-unsigned.apk xxxxxmobileapps 

要么

 D:\projects\Phonegap\Example\platforms\android\build\outputs\apk> jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore NAME-mobileapps.keystore Example-release-unsigned.apk xxxxxmobileapps Enter KeyPhrase as 'xxxxxxxx' 

这签署了apk的地方。

第六步:

最后,我们需要运行zipalignment工具来优化APK:

 D:\projects\Phonegap\Example\platforms\android\ant-build> zipalign -v 4 Example-release-unsigned.apk Example.apk 

要么

 D:\projects\Phonegap\Example\platforms\android\ant-build> C:\Phonegap\adt-bundle-windows-x86_64-20140624\sdk\build-tools\android-4.4W\zipalign -v 4 Example-release-unsigned.apk Example.apk 

要么

 D:\projects\Phonegap\Example\platforms\android\build\outputs\apk> C:\Phonegap\adt-bundle-windows-x86_64-20140624\sdk\build-tools\android-4.4W\zipalign -v 4 Example-release-unsigned.apk Example.apk 

现在我们有了我们的最终版本二进制文件example.apk,我们可以在Google Play商店上发布这个文件。

cordova4(及更高版本)的@malcubierre更新 –

创build一个名为APPFOLDER\platforms\android的文件,并放入APPFOLDER\platforms\android文件夹

文件内容:除第二行以外的所有内容

 storeFile=C:/yourlocation/app.keystore storeType=jks keyAlias=aliasname keyPassword=aliaspass storePassword=password 

那么这个命令应该build立一个发行版本:

 cordova build android --release 

在当前的文档中,我们可以用keystore指定一个build.json:

 { "android": { "debug": { "keystore": "..\android.keystore", "storePassword": "android", "alias": "mykey1", "password" : "password", "keystoreType": "" }, "release": { "keystore": "..\android.keystore", "storePassword": "", "alias": "mykey2", "password" : "password", "keystoreType": "" } } } 

然后,用–buildConfig参数执行这个命令,这样:

 cordova run android --buildConfig 

步骤1:

转到cordova\platforms\android ant用keystore文件信息创build一个名为ant.properties文件(这个keystore可以从你最喜欢的Android SDK,studio生成):

 key.store=C:\\yourpath\\Yourkeystore.keystore key.alias=youralias 

第2步:

去科多瓦的path执行:

 cordova build android --release 

注意:系统会提示您询问密钥库和密钥

YourApp-release.apk将出现在\cordova\platforms\android\ant-build

在cordova 6.2.0中 ,它有一个简单的方法来创build发布版本。 请参阅步骤1,2和4中的其他步骤

 cd cordova/ #change to root cordova folder platforms/android/cordova/clean #clean if you want cordova build android --release -- --keystore="/path/to/keystore" --storePassword=password --alias=alias_name #password will be prompted if you have any 

在Mac(osx)上,我生成了两个.sh文件,一个用于第一个发布,另一个用于更新:

 #!/bin/sh echo "Ionic to Signed APK ---- b@agencys.eu // Benjamin Rathelot\n" printf "Project dir : " read DIR printf "Project key alias : " read ALIAS cd $DIR/ cordova build --release android cd platforms/android/build/outputs/apk/ keytool -genkey -v -keystore my-release-key.keystore -alias $ALIAS -keyalg RSA -keysize 2048 -validity 10000 jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my-release-key.keystore android-release-unsigned.apk $ALIAS zipalign -v 4 android-release-unsigned.apk signedApk.apk 

并更新您的应用程序:

 #!/bin/sh echo "Ionic to Signed APK ---- b@agencys.eu // Benjamin Rathelot\n" printf "Project dir : " read DIR printf "Project key alias : " read ALIAS cd $DIR/ cordova build --release android cd platforms/android/build/outputs/apk/ rm signedApk.apk jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my-release-key.keystore android-release-unsigned.apk $ALIAS zipalign -v 4 android-release-unsigned.apk signedApk.apk 

假设你在你的家庭文件夹或一个文件夹上面的应用程序文件夹。 确保正确设置chmod以使用此脚本。 然后 :

 ./ionicToApk.sh # or whatever depending of the name of your file, in CLI 

您签名的apk将会在您的应用程序文件夹/ p​​latforms / android / build / outputs / apk /中作为SignedApk.apk确保使用第一个脚本定义的正确的密钥别名和密码

首先检查您的版本代码和版本名称,如果你正在更新你的应用程序。 并确保你有一个以前的密钥库。

如果您正在更新应用程序,然后按照步骤1,3,4。

步骤1:

转到您的cordova项目来生成我们的发布版本:

 D:\projects\Phonegap\Example> cordova build --release android 

然后,我们可以在platforms / android / ant-build中find我们未签名的APK文件。 在我们的例子中,文件是

如果你用antbuild立

 yourproject/platforms/android/ant-build/Example-release-unsigned.apk 

要么

如果你使用gradle-build

 yourProject/platforms/android/build/outputs/apk/Example-release-unsigned.apk 

第2步:

密钥生成:

句法:

 keytool -genkey -v -keystore <keystoreName>.keystore -alias <Keystore AliasName> -keyalg <Key algorithm> -keysize <Key size> -validity <Key Validity in Days> 

如果keytool命令不能识别这一步

检查keytool可执行文件所在的目录是否在你的path上。 (例如,在我的Windows 7机器上,它位于C:\ Program Files(x86)\ Java \ jre6 \ bin中。)

例:

 keytool -genkey -v -keystore NAME-mobileapps.keystore -alias NAMEmobileapps -keyalg RSA -keysize 2048 -validity 10000 keystore password? : xxxxxxx What is your first and last name? : xxxxxx What is the name of your organizational unit? : xxxxxxxx What is the name of your organization? : xxxxxxxxx What is the name of your City or Locality? : xxxxxxx What is the name of your State or Province? : xxxxx What is the two-letter country code for this unit? : xxx 

然后,密钥存储已经使用NAME-mobileapps.keystore名称生成

第3步:

将生成的密钥库放在D:\ projects \ Phonegap \ Example \ platforms \ android \ ant-build中

要签署未签名的APK,请运行也包含在JDK中的jarsigner工具:

句法:

 jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore <keystorename <Unsigned APK file> <Keystore Alias name> 

如果它不重新做这些步骤

(1)右键单击“This PC”>右键单击属性>高级系统设置>环境variables>selectPATH然后编辑。

(2)将您的jdk bin文件夹path添加到环境variables中,它应该如下所示:

“C:\ Program Files \ Java \ jdk1.8.0_40 \ bin”。

例:

 D:\projects\Phonegap\Example\platforms\android\ant-build> jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore NAME-mobileapps.keystore Example-release-unsigned.apk xxxxxmobileapps Enter KeyPhrase as 'xxxxxxxx' 

这签署了apk的地方。

步骤4:

最后,我们需要运行zipalignment工具来优化APK:

如果zipalign不能识别的话

(1)转到你的android sdkpath,findzipalign通常在android-sdk \ build-tools \ 23.0.3

(2)复制zipalign文件粘贴到您的生成释放apk文件夹通常在下面的path

yourproject /平台/机器人/ant构build/实施例离型unsigned.apk

 D:\projects\Phonegap\Example\platforms\android\ant-build> zipalign -v 4 Example-release-unsigned.apk Example.apk 

要么

 D:\projects\Phonegap\Example\platforms\android\ant-build> C:\Phonegap\adt-bundle-windows-x86_64-20140624\sdk\build-tools\android-4.4W\zipalign -v 4 Example-release-unsigned.apk Example.apk 

现在我们有了我们的最终版本二进制文件example.apk,我们可以在Google Play商店上发布这个文件。