zoukankan      html  css  js  c++  java
  • (转)quick-cocos2d-x基于源码加密打包功能的更新策略(3)

    前篇:

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

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

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

    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. 根据客户端请求时的参数能够做到版本分发

    后记

    对于方案的介绍到这里就告一段落了。后面这部分本来还想展开一下的,但后来觉得必要性没这么大,毕竟和大家分享的主要是解决方案而不是细节。

    希望我的分享对大家能有所帮助,也请大家对方案的不足之类多提意见!

    原文地址:https://my.oschina.net/SunLightJuly/blog/181599

  • 相关阅读:
    php 小试 mysql-zmq-plugin 和 pthreads
    svn:previous operation has not finished
    Http Header里的Content-Type
    sublime text使用及常见问题
    Less:优雅的写CSS代码
    gulp:更简单的自动化构建工具
    js实现『加载更多』功能实例
    JSONP浅析
    使用JSSDK集成微信分享遇到的一些坑
    JavaScript模板引擎实例应用
  • 原文地址:https://www.cnblogs.com/wodehao0808/p/9107649.html
Copyright © 2011-2022 走看看