1、首先執行以下命令 在android目錄下
keytool -genkey -v -keystore my-release-key.keystore -alias my-key-alias -keyalg RSA -keysize 2048 -validity 10000
這條命令會要求你輸入密鑰庫(keystore)和對應密鑰的密碼,然后設置一些發行相關的信息。最后它會生成一個叫做my-release-key.keystore
的密鑰庫文件。
在運行上面這條語句之后,密鑰庫里應該已經生成了一個單獨的密鑰,有效期為10000天。--alias參數后面的別名是你將來為應用簽名時所需要用到的,所以記得記錄這個別名。
2、設置gradle變量
把my-release-key.keystore
文件放到你工程中的android/app
文件夾下
編輯android/gradle.properties
(沒有這個文件你就創建一個),添加如下的代碼(注意把其中的****
替換為相應密碼)
MYAPP_RELEASE_STORE_FILE=my-release-key.keystore MYAPP_RELEASE_KEY_ALIAS=my-key-alias MYAPP_RELEASE_STORE_PASSWORD=***** MYAPP_RELEASE_KEY_PASSWORD=*****
上面的這些會作為全局的gradle變量,我們在后面的步驟中可以用來給應用簽名。
關於密鑰庫的注意事項:
一旦你在Play Store發布了你的應用,如果想修改簽名,就必須用一個不同的包名來重新發布你的應用(這樣也會丟失所有的下載數和評分)。所以請務必備份好你的密鑰庫和密碼。
3、添加簽名到項目的gradle配置文件
編輯你項目目錄下的android/app/build.gradle
,添加如下的簽名配置:
... android { ... defaultConfig { ... } signingConfigs { release { storeFile file(MYAPP_RELEASE_STORE_FILE) storePassword MYAPP_RELEASE_STORE_PASSWORD keyAlias MYAPP_RELEASE_KEY_ALIAS keyPassword MYAPP_RELEASE_KEY_PASSWORD } } buildTypes { release { ... signingConfig signingConfigs.release } } } ...
4、見證奇跡的時候到了,生成apk包
在android目錄下執行
gradlew assembleRelease
譯注:cd android表示進入android目錄(如果你已經在android目錄中了那就不用輸入了)。./gradlew assembleRelease
在macOS、Linux或是windows的PowerShell環境中表示執行當前目錄下的名為gradlew的腳本文件,且其運行參數為assembleRelease,注意這個./
不可省略;而在windows的傳統CMD命令行下則需要去掉./
。
Gradle的assembleRelease
參數會把所有用到的JavaScript代碼都打包到一起,然后內置到APK包中。如果你想調整下這個行為(比如js代碼以及靜態資源打包的默認文件名或是目錄結構等),可以看看android/app/build.gradle
文件,然后琢磨下應該怎么修改以滿足你的需求。
生成的APK文件位於android/app/build/outputs/apk/app-release.apk
,它已經可以用來發布了。
5、測試應用的發行版本
gradlew installRelease
注意installRelease
參數只能在你完成了上面的簽名配置之后才可以使用。 你現在可以關掉運行中的packager了,因為你所有的代碼和框架依賴已經都被打包到apk包中,可以離線運行了。
在debug和release版本間來回切換安裝時可能會報錯簽名不匹配,此時需要先卸載前一個版本再嘗試安裝。