React Native Android生成已签名的APK

黄沙百战穿金甲,不破楼兰终不还。这篇文章主要讲述React Native Android生成已签名的APK相关的知识,希望能为你提供帮助。
要通过Google  Play  store或者其它渠道发布应用,你需要生成一个签名的发行版APK包。android开发者文档中的为你的应用程序签名已经说明了相应的内容。本向导会简略的介绍这些过程,然后着重讲解如何打包javascript代码。
 
生成一个签名密钥
 
你可以用keytool命令生成一个私有密钥。
在命令窗口敲入以下内容
keytool  -genkey  -v  -keystore  my-release-key.keystore  -alias  my-key-alias  -keyalg  RSA  -keysize  2048  -validity  10000
注意:黄色标注的分别是秘钥库文件和秘钥库别名,有很多地方用到这个。
注意:每一次发行apk,keystore  后面的内容需要改alias  后面的内容也要改。
这条命令会要求你输入密钥库(keystore)和对应密钥的密码,然后设置一些发行相关的信息。最后它会生成一个叫做my-release-key.keystore的密钥库文件。
如图:

React Native Android生成已签名的APK

文章图片

在运行上面这条语句之后,密钥库里应该已经生成了一个单独的密钥,有效期为10000天。--alias参数后面的别名是你将来为应用签名时所需要用到的,所以记得记录这个别名。
  将生成的秘钥库文件放到如图所示的项目位置
 
React Native Android生成已签名的APK

文章图片

编辑~/.gradle/gradle.properties,添加如下的代码(注意把其中的****替换为相应密码)
MYAPP_RELEASE_STORE_FILE=my-release-key.keystoreMYAPP_RELEASE_KEY_ALIAS=my-key-aliasMYAPP_RELEASE_STORE_PASSWORD=*****MYAPP_RELEASE_KEY_PASSWORD=*****

 
如图
React Native Android生成已签名的APK

文章图片

 
 
 
注:一旦你在Play  Store发布了你的应用,如果想修改签名,就必须用一个不同的包名来重新发布你的应用。所以请务必备份好你的签名库和密码
添加签名到应用的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 } } }...

 
如图
【React Native Android生成已签名的APK】
React Native Android生成已签名的APK

文章图片

生成发行APK包
如果你在android/app下有一个react.gradle
 
只要在终端下运行以下命令:
 
$  cd  android  & &   ./gradlew  assembleRelease
React Native Android生成已签名的APK

文章图片

成功后
 
React Native Android生成已签名的APK

文章图片

你应该能在android/app/build/outputs/apk/app-release.apk中找到生成的APK文件,并且它已经可以用来被发布。
 
React Native Android生成已签名的APK

文章图片

 

    推荐阅读