关注web技术发展
用心做好每一件事

React Native Android打包签名apk

最近开始玩react-native,直接生成的包,手机不能安装,提示未签名,网上找了找签名教程,但多数都是基于android-studio,最后找到几篇好的教程,测试ok,整理一下。

生成一个签名密钥

在命令窗口敲入以下内容

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

注意:toushi-release-keytoushi-key-alias分别是秘钥库文件和秘钥库别名,有很多地方用到这个。

注意:每一次发行apk,keystore 后面的内容需要改alias 后面的内容也要改。

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

如图:
忽略图片内容,测试忘了截图,图片手机别人的
在运行上面这条语句之后,密钥库里应该已经生成了一个单独的密钥,有效期为10000天。--alias参数后面的别名是你将来为应用签名时所需要用到的,所以记得记录这个别名。

将生成的秘钥库文件放到android/app目录下

编辑~/.gradle/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=*****

注:一旦你在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 //别漏了这行
        }
    }
}

...

生成发行APK包

只要在终端下运行以下命令:

$ cd android && gradlew assembleRelease

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

分享到: 更多 (0)

我要点评 1

评论前必须登录!

 

  1. #1

    感谢分享

    绿软库2个月前 (12-15)