网站大量收购闲置独家精品文档,联系QQ:2885784924

Blend 离线缓存方案.pdf

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Blend 离线缓存方案

Blend 离线缓存⽅案 在 webapp 开发中,数据存储和离线可访问是每个开发者遇到的难题,也是影响⽤户 体验的 要⼀环;为了克服缺陷,HTML不断推出新接⼝,从Cookie延续到 localStorage 、 Web SQL DataBase和AppCache,但现存的接⼝依然存成如下问 题: 1. 存储量有限,存储形式太过单⼀; cookie存储数量和⼤⼩都有所限制,存储形式上按照字符串进⾏拼接; 新推出的 localStorage对cookie有很好补充作⽤,提供key-value键值对存储,但⼤⼩依然受 限,不提供结构化存储; 2. 系统⽀持程度不统⼀,⽆法保证成功率; a droid分⽀越来越多,对应的web api⽀持情况也更加多样;如对结构化存储⽀持很 好的i dexedDB接⼝,必须运⾏在a droid⼤于4.3 ,ios⼤于8.1的版本;接⼝⽀持的不 统⼀,很难保证成功率; 3. ⽆法满⾜对⽂ 内容的存储和获取; 现在还没有接⼝可以读取和存储⽂件, 为了保证离线可访问必须对⽂件内容进⾏存 取; 4. ⽆法实时更新,最终结果⽆法预料; ⻚⾯采⽤Cache Ma ifest可实现⻚⾯离线可访问, 但⽤户⽆法实时更新,内容更新之 后须修改配置⽂件当⽤户第⼆次刷新时可看到新的内容; 5. 接⼝使⽤太过复杂,各个接⼝互相孤⽴; 保证webapp离线可访问是个系统⼯程,牵涉到存储、⽹络检测、⽂件读取、安全 等,现存的接⼝是不同时期推出,每个接⼝仅是为了解决局部问题引⼊,没有系统性 的集合起来供⽤户使⽤; 从分析情况来看,依靠纯web提供的接⼝⽆法完全满⾜需求,百度Clouda+近期1.2版 本发布,提供了另⼀种离线缓存⽅案; Clouda+离线⽅案 通过分析web提供的api,须在⾃⼰控制的系统中设计⼀套独⽴的API,需要有下⾯⼏ 个模块: 存储模块 为了提⾼检索速度,⽀持结构化存储和索引查询数据;因要存储⼤量静态资源⽂ 件,存储⼤⼩应该不受限制; ⽹络模块 此模块内可以拦截⽹络请求,对拦截的请求内容存储到本地,保证离线时获取; 还可以对⽹络情况进⾏判断,使其从不同渠道获取内容; ⽂件模块 拦截了请求之后,下⼀步就必须把此请求的⽂件内容进⾏存储或者读取,⽂件 I/O操作必不可少; 安全模块 数据下载到了⼿机空间中,必须对⽂件进⾏安全加密和访问限制,保证数据安全 Clouda+的Ru time提供了webapp运⾏环境,此⽅案设计也架构在了Ru time之中, 下⾯是其架构图: ⽹络拦截和⽹络环境模块提供⽹络接⼝,通过对⽹络环境的判断来确定是否拦截⽹络 请求;数据存储模块是个精简的数据库系统,⽤户可存储或者索引数据;⽂件存储提 供了对⽂件的下载和读取;访问策略和安全加密提供了安全模块,来限制⽂件的⾃由 读取; ⽅案优势 1. 存储量不再受限制; 存储量仅和⽤户⼿机空间⼤⼩相关; 2. ⽀持了⽂ 下载和读取; 通过对⽂件下载和读取接⼝,⽤户可以把图⽚、⻚⾯内容或者数据等⽅便下载到⼿机 空间中,突破web⽆法操作⽂件的限制; 3. 不受⼿机⾃身webview版本的限制; Clouda+的数据或者⽂件存储都是依靠框架⾃身能⼒实现,不依赖⼿机本身,也就是 只要升级到Clouda+必威体育精装版版本,都完美⽀持此功能; 4. 离线访问可⾃由控制,保证实时性和离线可访问性; Clouda+设置了拦截器开关,可⾃由拦截⽹络资源,是否⽤离线数据⽤户可⾃由控 制; 5. 对接⼝就⾏了整合封装,⼏乎可零配置⽀持⽹络资源离线访问; Clouda+对各个接⼝基础上进⾏了封装,⽤户⼏乎零配置就可以让其webapp⽀持离线 访问; 如何使⽤ 使⽤Clouda+离线缓存技术必须在其提供的Ru time环境下进⾏开发, 引⼊clouda+⼊ ⼝脚本⽂件loader ;提供了智能的离线缓存和 动调⽤⽅式: 智能化配置 1. ⾸⻚载⼊cache模块且进⾏初始化; Blend.lightInit({ ak: xxxxxxxxxx, // 百度开发者平台提供的appKey module: [cache] }, unction(){ Blend.device.cache.init();// 加载完成后初始化 }); 2. ⻚⾯head头部引⼊meta标签,配置需要缓存的资源; 如⾃动缓存图⽚资源侧添加如下:

文档评论(0)

jiupshaieuk12 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:6212135231000003

1亿VIP精品文档

相关文档