admin 管理员组文章数量: 887021
ios html页面本地缓存,iOS
一、离线包缓存的简介
离线包缓存含几个包的概念:
预装包:指通过脚本文件在程序编译时期下载的包。
增量包:指通过包的文件比对,生成的diff文件(差量包)
全量包:指完整的包文件
CCCandyWebCache离线包缓存的逻辑
第一次启动的时候先请求预装包接口安装预装包,同时将预装包请求的response配置表放在本地中,获取预装包zip的文件名字,先去判断是否在预装包配置表里面,然后判断预装包文件的MD5值和预装包配置表fullPackageMD5是否匹配。如果信息都匹配上则将预装包移动到指定的本地目录下(....../webapps/res/),然后解压预装包zip文件。
预装包解压成功后,会将本地包的信息组装成body去请求检查更新接口,将返回的数据结构转模型,根据state判断是否需要更新,如果要的话去判断是全量更新还是增量更新。然后和本地数据库的模块名字对比是否有匹配,有的话判断该包是否正在更新或者有其他错误状态,如果状态是正确的则使用版本号做对比,看是否需要更新包,如果服务器返回数据的版本号更大则去更新资源。
如果是增量更新,将diff文件下载下来后,将其MD5值与请求更新的response的对应模块的MD5值做匹配,匹配失败则做全量更新,如果匹配成功则开始增量合并,如果本地老的资源zip包已经不存在则增量合并失败,做全量更新。如果增量包合并失败则进行全量更新。增量包合并成功则解压zip包,替换掉原来的解压后的文件。资源更新成功清除内存缓存。
全量更新,下载成功后,匹配zip包的MD5值,如果成功则移除原来的模块文件,然后进行解压。
每次启动都会去请求检查更新这个接口,判断资源是否需要更新。
拦截的URl的时候,先判断URL 是否包含本地存储的domain,包含则进行本地资源匹配,然后匹配上则去加载本地的html,css,js,等文件。否则正常去请求这个URL。
二、集成SDK遇到的坑
1.因为使用swift项目,pod是动态库,所以需要用本地库去pod
1.SDK的podspec 去掉了作者信息,导致pod不成功.所以要加上
2.SDK的podspec ,homepage 指向不对,导致pod不成功.
本文标签: ios html页面本地缓存 iOS
版权声明:本文标题:ios html页面本地缓存,iOS 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/free/1700310537h391071.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论