React-Native 热更新 CodePush

10 篇文章 0 订阅
3 篇文章 0 订阅
  • 0.网上资料和官网最新的不一样
  • 1.安装CodePush: npm install -g code-push-cli
  • 2.创建CodePush账号: code-push register (会打开网页进行注册,有点卡)
  • 3.复制 token到控制台
  • 4.在CodePush服务器上注册app:
    1. code-push app add MyApp-iOS ios react-native
    2. code-push app add MyApp-Android android react-native
    3. 复制部署秘钥staging或(code-push deployment ls appName)
  • 5.项目安装SDK:
    1. npm install --save react-native-code-push
    2. react-native link react-native-code-push
    3. 复制staging 到 MainApplication.java 里deployment-key-here
    4. 调用sync函数
    5. code-push release-react MyApp-Android android
  • 相关命令3
    1. code-push login 登陆
    2. code-push loout 注销
    3. code-push access-key ls 列出登陆的token
    4. code-push access-key rm 删除某个 access-key
  • 相关命令4
    1. code-push app add 在账号里面添加一个新的app
    2. code-push app remove 或者 rm 在账号里移除一个app
    3. code-push app rename 重命名一个存在app
    4. code-push app list 或则 ls 列出账号下面的所有app
    5. code-push app transfer 把app的所有权转移到另外一个账号
    6. 发布更新
    1. 第一种方式:通过code-push release-react发布更新
    1. code-push release-react MyApp-iOS ios
    2. code-push release-react MyApp-Android android
    3. code-push release-react MyApp-iOS ios --t 1.0.0 --dev false --d Production --des “1.优化操作流程” --m true
    1. 其中参数–t为二进制(.ipa与apk)安装包的的版本;–dev为是否启用开发者模式(默认为false);–d是要发布更新的环境分Production与Staging(默认为Staging);–des为更新说明;–m 是强制更新
    2. 通过code-push release发布更新(收藏)
    7. 应用创建时有两个环境,一个是Staging,一个是Production,开发阶段用Staging,开发完成可以用code-push promote 将应用迁移到Production中
    8. code-push patch 应用名 Production -r 100%
  • 相关命定5
    1. code-push deployment add 部署
    2. code-push deployment rename 重命名
    3. code-push deployment rm 删除部署
    4. code-push deployment ls 列出应用的部署情况
    5. code-push deployment ls -k 查看部署的key
    6. code-push deployment history 查看历史版本(Production 或者 Staging)

相关代码5.4

	
CodePush.sync(
	options: Object, 
	syncStatusChangeCallback: function(syncStatus: Number), 
	downloadProgressCallback: function(progress: DownloadProgress)
): Promise<Number>;
传入三个参数
1. options = { installMode: CodePush.InstallMode.IMMEDIATE, updateDialog: true }
	installMode (codePush.InstallMode): 安装模式,用在向CodePush推送更新时没有设置强制更新(mandatory为true)的情况下,默认codePush.InstallMode.ON_NEXT_RESTART即下一次启动的时候安装。
	mandatoryInstallMode (codePush.InstallMode):强制更新,默认codePush.InstallMode.IMMEDIATE
	updateDialog (UpdateDialogOptions) :可选的,更新的对话框,默认是null,包含以下属性
		appendReleaseDescription (Boolean) - 是否显示更新description,默认false
		descriptionPrefix (String) - 更新说明的前缀。 默认是” Description: “
		 mandatoryContinueButtonLabel (String) - 强制更新的按钮文字. 默认 to “Continue”.
		mandatoryUpdateMessage (String) - 强制更新时,更新通知. Defaults to “An update is available that must be installed.”.
		optionalIgnoreButtonLabel (String) - 非强制更新时,取消按钮文字. Defaults to “Ignore”.
		optionalInstallButtonLabel (String) - 非强制更新时,确认文字. Defaults to “Install”.
		optionalUpdateMessage (String) - 非强制更新时,更新通知. Defaults to “An update is available. Would you like to install it?”.
		title (String) - 要显示的更新通知的标题. Defaults to “Update available”.
		具体可以查看我上面的代码:
		还有一个是:codePush.InstallMode,有三种模式,
			一个是立即启动,nstallMode.IMMEDIATE 
			一个是下次启动安装:InstallMode.ON_NEXT_RESTART
			一个是程序在前台,并没有从后台切换到前台的情况下用的InstallMode.ON_NEXT_RESUME
2.状态
3.进度

安装签名

	keytool -genkey -v -keystore my-release-key.keystore  -alias my-key-alias -keyalg RSA -keysize 2048 -validity 10000
	注意上面的my-release-key这个名字可以自己取名,同时my-key-alias也是自己取名,其中第二个名称alias参数后边的别名,在后面你在为应用签名的时候需要用到,所以暂时记录一下这个别名
	添加签名
	signingConfigs {
            release {
                storeFile file('../keystores/rn-test.keystore')
                storePassword 'name'
                keyAlias 'name'
                keyPassword 'name'
            }
        }
	buildTypes {
        release {
            signingConfig signingConfigs.release
        }
    }
	
	./gradlew assembleDebug 编译并打Debug包
	./gradlew assemblexiaomiDebug 编译并打xiaomi的debug包,其他类似
	./gradlew assembleRelease 编译并打Release的包
	./gradlew assemblexiaomiRelease 编译并打xiaomi的Release包,其他类似
	./gradlew installRelease Release模式打包并安装
	./gradlew uninstallRelease 卸载Release模式包


React-Native 篇

七分设计感的纯React-Native项目Mung

一个完整小巧的Redux全家桶项目

react-native拖拽排序

多功能React-Native-Toast组件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值