React Native 打包APK(Windows)
1、生成一个签名秘钥: 在Windows上直接使用Java_JDk自带的keytool工具生成密钥,工具放在JDK的bin目录中(比如C:Program Files(x86)Javajdkx.x.x_xbin)如下图所示:
接下来使用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:UsersAdministrator文件下找到一个叫做my-test1-key.keystore的密钥库文件,如果没有的话,在C:Program Files(x86)Javajdkx.x.x_xbin找一下! 注意:请记得妥善地保管好你的密钥库文件,不要上传到版本库或者其它的地方。如果提示不是内部命令的话,请检查一下Java的环境配置问题! 2、设置gradle变量
如下图:
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,它已经可以用来发布了。
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |