quick-cocos2d-x基于源码加密打包功能的更新策略(3) (转)

转载自 http://my.oschina.net/SunLightJuly/blog/181599


三、更新流程说明及特性分析

A.更新流程

  1. 加载初始安装包,载入旧资源列表
  2. 取最新资源列表文件,载入新资源列表
  3. 比较两个资源列表版本,如果一致,跳到第8步;以下流程中如果有误也跳到第8步
  4. 根据新资源列表检查现有文件,逐一下载新增或者有变化的文件,并加.upd后缀保存
  5. 每个下载的文件在保存后马上进行一次校验
  6. 所有文件下载完成,更新本地资源列表文件,用新列表替换旧列表
  7. 将下载的文件去掉.upd后缀,覆盖旧的文件
  8. 根据资源列表再校验一遍资源文件
  9. 第8步正确,则按资源列表的指示载入相关资源,启动程序(新版本)
  10. 第8步有错,说明资源列表与资源文件不匹配,删除本地资源列表文件(保证下次启动时重新更新资源),启动程序(原始安装版本)

B.安全性

可以看出在第6步之前,即使出错,也不会破坏原来的文件。跳到第8步后,一般能够以上一个更新成功的版本启动,除非上一个版本被用户破坏。

第6步和第7步出错,会造成资源列表与资源文件不匹配,跳到第8步后,肯定只有从原始版本启动了。

第8步错误,有可能是因为前面出错,也有可能是用户自己破坏了本地文件。无论如何,还是能从原始版本启动,并保证下次进入能再次更新。

第8步正确,并不一定说明这次更新是成功的,但启动起来的一定是最后一次更新成功的版本。

因此我们可以确认,只要update模块本身流程没有问题,此更新方案是安全的。

C.其他特性

  1. 对于确定的终端,服务器端只需要维护一个最新版本的文件列表。不管客户端是什么版本,都能直接升级到新版本
  2. 本地已经下载过的文件不会再次下载,只做增量更新
  3. 本次更新下载了部分文件但未完成最后更新,下次更新,已经下载成功的文件不会再重复下载
  4. 代码经过压缩,减少下载量
  5. 根据客户端请求时的参数能够做到版本分发

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值