本地实际应用建议绑定当前的用户,解决不能用户看到不同的缓存,可以做下适当的包装,比如:
setCache:function(key,value,exp){ //过期时间默认1天 exp=exp||86400; store.set(key+'_'+curUserID, value,exp); }, getCache:function(key){ return store.get(key+'_'+curUserID); }
另外还又可以尝试结合一些简单的加解密技术,来保证客户端缓存数据的相对安全,但势必会造成性能上的损失。
数据加密已经完成,具体见:store_code.js,对数据的存储和获取分别做了加解密。
//简单的缓存 store.set('a',{a:1,b:2}) //增加过期时间:单位是秒 store.set('a',{a:1,b:2},3600) //清除指定缓存 store.set('a',null) //或者 sotre.set('a');//为了代码的可读性,不建议这样使用
store.get('a') //log:{a:1,b:2}
store.del('a');
store.clearExp();
store.clearAll()
//和set的区别是,这个会检测是否已经存在同名的缓存,如果存在,就不做任何处理 // 单set是会覆盖当前值的 store.add('b',{c:1,d:1},3600)
//过期时间由原来的1小时,变成了2小时,并且是从创建时间计算的 store.setExp('a',7200)
store.getExp('a')