Skip to content

Latest commit

 

History

History
61 lines (43 loc) · 3.47 KB

README.cn.md

File metadata and controls

61 lines (43 loc) · 3.47 KB

CodePush 服务端

微软官方的 CodePush 在国内的网络访问较慢, 所以我们使用这个服务端来架设自己的 CodePush 服务

关于本项目

因为原 code-push-server 项目的作者没有积极维护了, 我们创建了这个项目用来:

  • 保持依赖更新
  • 修复任何与最新的客户端的兼容问题
  • 我们只使用官方的 react-native-code-push 客户端, 所以定制的功能, 比如 is_use_diff_text 会被放弃.
  • 我们只在生产环境使用了 react-native-code-push, 对于其他的 CodePush 客户端, 大部分功能应该没有差别, 如果遇到任何问题的话, 都欢迎提交 issue 或者 PR.

支持的存储方式

  • local: 在本地硬盘存储包文件
  • qiniu: 在七牛云存储包文件
  • s3: 在aws存储包文件
  • oss: 在阿里云存储包文件
  • tencentcloud: 在腾迅云存储包文件

正确使用 code-push 热更新

  • 苹果 App 允许使用热更新Apple's developer agreement, 为了不影响用户体验,规定必须使用静默更新。 Google Play 不能使用静默更新,必须弹框告知用户 App 有更新。中国的 android 市场必须采用静默更新(如果弹框提示,App 会被“请上传最新版本的二进制应用包”原因驳回)。
  • react-native 不同平台 bundle 包不一样,在使用 code-push-server 的时候必须创建不同的应用来区分(eg. CodePushDemo-ios 和 CodePushDemo-android)
  • react-native-code-push 只更新资源文件,不会更新 java 和 Objective C,所以 npm 升级依赖包版本的时候,如果依赖包使用的本地化实现, 这时候必须更改应用版本号(ios 修改 Info.plist 中的 CFBundleShortVersionString, android 修改 build.gradle 中的 versionName), 然后重新编译 app 发布到应用商店。
  • 推荐使用 code-push release-react 命令发布应用,该命令合并了打包和发布命令(eg. code-push release-react CodePushDemo-ios ios -d Production)
  • 每次向 App Store 提交新的版本时,也应该基于该提交版本同时向 code-push-server 发布一个初始版本。(因为后面每次向 code-push-server 发布版本时,code-puse-server 都会和初始版本比较,生成补丁版本)

CodePush 命令行

code-push-cli 是用来管理 App 以及发布 CodePush 版本的, 请查看命令行项目的说明了解更多

客户端

如何安装 code-push-server

默认帐号和密码

  • 帐号: admin
  • 密码: 123456

常见问题