React Native 打包APKWindows

1、生成一个签名秘钥:

在Windows上直接使用Java_JDk自带keytool工具生成密钥,工具放在JDK的bin目录中(比如C:\Program Files(x86)\Java\jdkx.x.x_x\bin如下图所示:


接下来使用keytool命令生成

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


这条命令会要求你输入密钥库(keystore)和对应密钥的密码,然后设置一些发行相关的信息。最后它会生成一个叫做my-test1-key.keystore的密钥库文件

在运行上面这条语句之后,密钥库里应该已经生成一个单独的密钥,有效期为10000天。--alias参数后面的别名是你将来为应用签名时所需要用到的,所以记得记录这个别名。

你就可以在 C:\Users\Administrator文件下找到一个叫做my-test1-key.keystore的密钥库文件,如果没有的话,在C:\Program Files(x86)\Java\jdkx.x.x_x\bin找一下!

注意:请记得妥善地保管好你的密钥库文件,不要上传到版本库或者其它的地方。如果提示不是内部命令的话,请检查一下Java的环境配置问题!

2、设置gradle变量

  1. my-test1-key.keystore文件放到你工程中的android/app文件夹下。
  2. 编辑~/.gradle/gradle.properties(没有这个文件你就创建一个),添加如下的代码(注意把其中的****替换为相应密码

如下图:

MYAPP_RELEASE_STORE_FILE=my-test1-key.keystore
MYAPP_RELEASE_KEY_ALIAS=my-key-test1
MYAPP_RELEASE_STORE_PASSWORD=*****
MYAPP_RELEASE_KEY_PASSWORD=*****

3、添加签名到项目的gradle配置文件

编辑你项目目录下的android/app/build.gradle添加如下的签名配置:

android {
    ......
    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 {
            minifyEnabled enableProguardInReleaseBuilds
            proguardFiles getDefaultProguardFile("proguard-android.txt"),"proguard-rules.pro"
            signingConfig signingConfigs.release
        }
    }
   ......
}

4、生成发行APK包

在打包之前记得在打包规则中添加
# react native
-dontwarn java.nio.file.Files
-dontwarn java.nio.file.Path
-dontwarn java.nio.file.Openoption
-dontwarn org.codehaus.mojo.animal_sniffer.IgnoreJRERequirement

-keep class com.google.android.gms.** { *; }
-dontwarn com.google.android.gms.**
-dontwarn butterknife.**

只需在终端中运行以下命令:

gradlew assembleRelease



如上图所以,打包成功~生成的APK文件位于 android/app/build/outputs/apk/app-release.apk,它已经可以用来发布了。

相关文章

一、前言 在组件方面react和Vue一样的,核心思想玩的就是组件...
前言: 前段时间学习完react后,刚好就接到公司一个react项目...
前言: 最近收到组长通知我们项目组后面新开的项目准备统一技...
react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom...