RN小食

rn的两种打包方式(Android & iOS)

2019-05-20  本文已影响0人  今天你撒谎了吗

一、Android

相对简单,文档(https://reactnative.cn/docs/signed-apk-android/)也有介绍。

1.生成私有秘钥

①根目录下打开终端,执行命令:

    keytool -genkey -v -keystore my-release-key.keystore -alias my-key-alias -keyalg RSA -keysize2048-validity10000

②根据提示输入口令:

one

只需记住 密钥库口令 (划重点)后面会用到,其他的不重要。

③生成密钥库文件

按下回车后,根目录下生成一个 my-release-key.keystore 的文件,直接拿到android/app下:

two

2.设置 gradle 变量:

①在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=******

其中******换成 密钥库口令 (重点)

3.添加签名配置:

①在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

            }

        }

        splits {

            ....   

         }   

         buildTypes {        

            release {

                signingConfig signingConfigs.release

                ...        

            }    

        }  

        .....            

    }

4.生成发行 APK 包

①终端cd到android目录下(我直接在android目录下新开一个终端,方便同时打包且重新运行项目更改),执行命令:

gradlew clean (不clean也能打包,但是安装后容易造成APP闪退的问题)

gradlew assembleRelease

需要注意的是每次打包之前最好删除android和android/app文件下的build包,清除之前的缓存。

②success之后生成的apk文件位于android/app/build/outputs/apk/release/app-release.apk,扫码下载安装或是发布到应用商店方式看需求就可以使用了。

二、iOS

1.关于APP IDS ,签名,证书等

像Android需要在终端生成私有密钥一样,只不过iOS需要在https://developer.apple.com/中创建。

①需要交费获得具有开发功能的AppleID(这里是能登录苹果设备以及开发网址的邮箱形式用户名,与标题中不是一个ID),登陆成功后进入Certificates, Identifiers & Profiles页面。

②添加Identifiers -> APP IDs,点击 + 号新建:

three

Name可以随意不作要求,Bundle ID通常格式:com.公司名.项目名

App Services根据需求勾选,continue后register

③创建证书

新建后选择App Store and Ad Hoc,continue直到choose file

four

打开钥匙串访问,从证书颁发机构请求证书,

five six

生成CertificateSigningRequest.certSigningRequest文件

回到choose file,选择的就是这个文件。

continue后下载,添加至钥匙串访问我的证书中。OK

④配置Provisioning Profiles -> distribution

选择App Store后continue,APP ID会自动填充刚才创建的ID以及证书,取一个

Profile Name,就能使当前配置处于活跃状态。

2.关于静态资源打包

①在ios文件夹下新建bundle文件。

②在项目根目录下执行命令:

react-nativebundle --entry-file index.js --bundle-output ./ios/bundle/index.ios.jsbundle --platform ios --assets-dest ./ios/bundle --devfalse

insert

将生成的一个文件夹及一个文件直接拖拽到Xode项目文件下就行。

3.关于xcode打包

①首先,bundle identifier换成之前的Bundle ID(com.公司名.项目名),team选择开发者账号

seven

②product -> archive(成功的前提是解决所有出现的报错。。废话!)

在弹出的organizer框中直接选择distribute app,有四种打包方式:

——iOS APP store(上传至苹果商店)

上传之前首先需要在https://appstoreconnect.apple.com/WebObjects/iTunesConnect.woa/ra/ng/app/1232529584 

我的APP中新建

eight

之后再回到xcode中

nine

接下来:upload -> Automatically manage signing -> Upload 坐等successfully uploaded

在我的APP中填写所需信息,按要求上传截图,架构等信息,保存后提交去审核就可以了。

——ad hoc(可以开发者内部测试,不需要签名证书等,可以直接在真机测试过或者添加了unid的设备上安装下载APP,其他设备不可以)

ten eleven twelve

接下来Export到你想放的文件夹,打开发现里面有IPA文件,就可以自行内测了。

——enterprise (企业内测,没有试过不做解释)

——development(与ad hoc相似,但是需要签名证书等,没有试过不做解释)

以上。

上一篇 下一篇

猜你喜欢

热点阅读