Chrome浏览器扩展开发系列之八:Chrome扩展的数据存储
Google Chrome浏览器扩展可以使用如下任何一种存储机制:
- HTML5的localStorage API实现的本地存储(此处略)
- Google的chrome.storage.* API实现的浏览器存储
- Google的chrome.cookies.* API实现的cookie存储
1) chrome.storage API实现的浏览器存储
Chrome浏览器扩展通过chrome.storage.* API,可以存取数据或监听数据的变化。
在manifest.json文件中注册storage如下:
{
"permissions": [
"storage"
],
}
chrome.storage.* API提供了chrome.storage.sync, chrome.storage.local和chrome.storage.managed三种存储空间类型。chrome.storage.local方式只能够将数据存储在当前登录的设备本地。
chrome.storage.sync方式实现了自动数据同步,相同的用户无论使用什么物理设备,只要以相同的账户登录即可访问存储的数据。设备离线时数据存储在本地,一旦设备上线则同步数据。如果用户禁止了数据同步,则采用chrome.storage.local方式。
chrome.storage.managed方式是只读存储,只有域管理员能够在其中存储数据,Chrome浏览器扩展只能读取其中的数据。
chrome.storage机制采用一系列的存储格子(tubes)存储数据,存储空间有限。存储数据时只能一个一进行写入操作,并发性能不高。
下面以chrome.storage.sync为例介绍具体方法的使用:
- 存储一个或多个数据
chrome.storage.sync.set(object items, function() {...})
其中的items对象包含若干“键值对”的映射,一个键值对就是一个存储的数据项。
- 获取指定key的数据项
chrome.storage.sync.get(string or array of string or object keys, function(object items) {...})
其中的keys如果为null则返回全部存储的数据项,如果为””或[]将返回空对象{}。
回调函数中的items对象就是获取的数据项,其中包含“键值对”的映射。
- 删除指定key的一个或多个数据项
chrome.storage.sync.remove(string or array of string keys, function() {...})
- 清空存储的所有数据项
chrome.storage.sync.clear(function(){…})
- 获取当前已经被使用的存储空间的数量(以字节为单位)
chrome.storage.sync.getBytesInUse(string or array of string keys, function(integer bytesInUse) {...})
其中的keys属性是数据项的key,如果为null表示取全部数据项的使用空间,””或[]将返回0
此外,对于某些敏感数据的变化,可以通过onChanged事件进行监听。存储格子中的任何变化都将触发该事件,示例如下:
chrome.storage.onChanged.addListener(function(changes, namespace) {
for (key in changes) {
var storageChange = changes[key];
console.log('Storage key "%s" in namespace "%s" changed. ' +
'Old value was "%s", new value is "%s".',
key, //数据的索引key
namespace, //数据的存储空间类型,枚举值"sync", "local", "managed"
storageChange.oldValue,//变化前的值
storageChange.newValue); //变化后的值
}
});
回调函数中的changes对象包含了所有发生变化了的数据的key(string类型)和变化前后的值(StoreageChange类型),数据结构如下:
changes:{
key1: obj
key2: obj2
…
keyn: objn
}
2) chrome.cookies.* API实现的cookie存储
Chrome浏览器扩展通过chrome.cookies.* API,可以获取或修改cookie,还可以监控cookie的变化。
在manifest.json文件中声明cookie权限以及要访问的域如下:
{
"permissions": [
"cookies",
"*://*.google.com"
],
}
chrome.cookies.Cookie对象的属性如下:
|
属性名 |
类型 |
必选/可选 |
注释 |
|
name |
string |
必选 |
Cookie对象的名字 |
|
value |
string |
必选 |
Cookie对象的值 |
|
domain |
string |
必选 |
Cookie对象适用的域 |
|
path |
string |
必选 |
Cookie对象适用的URL路径 |
|
hostOnly |
boolean |
必选 |
Cookie对象是否只响应指定主机的请求,访问Cookie对象的请求的主机必须在指定范围内 |
|
secure |
boolean |
必选 |
Cookie对象是否被标记为Secure,这样就只能通过安全通道(如HTTPS)访问Cookie对象 |
|
httpOnly |
boolean |
必选 |
Cookie对象是否被标记为HttpOnly,这样客户端脚本就无法访问Cookie对象 |
|
session |
boolean |
必选 |
是否为Session级别的Cookie对象 |
|
expirationDate |
double |
可选 |
Cookie对象的过期时间,单位s Session级别的Cookie对象没有该属性,因为会话结束即过期 |
|
storeId |
string |
必选 |
包含该Cookie对象的CookieStore的ID |
其中,chrome.cookies.CookieStore对象表示浏览器中的cookie仓库,常见的有正常模式的CookieStore和隐身模式的CookieStore。
chrome.cookies API中的常用方法:
- 获得一个Cookie对象,如果有多个符合过滤条件则返回拥有最长path的Cookie对象
chrome.cookies.get(object details, function(Cookie cookie) {...})
details对象的属性如下:
|
属性名 |
类型 |
必选/可选 |
注释 |
|
url |
string |
必选 |
访问Cookie对象的请求的URL |
|
name |
string |
必选 |
Cookie对象的名字 |
|
storeId |
string |
可选 |
包含该Cookie对象的CookieStore的ID,默认为当前执行的上下文的CookieStore |
- 获取一个CookieStore中的所有的Cookie对象
chrome.cookies.getAll(object details, function(array of Cookie cookies) {...})
details对象的属性如下:
|
属性名 |
类型 |
必选/可选 |
注释 |
|
url |
string |
可选 |
访问Cookie对象的请求的URI,影响domain和path |
|
name |
string |
可选 |
Cookie对象的名字 |
|
value |
string |
可选 |
Cookie对象的值 |
|
domain |
string |
可选 |
Cookie对象适用的域 |
|
path |
string |
可选 |
Cookie对象适用的URL路径 |
|
secure |
boolean |
可选 |
Cookie对象是否被标记为Secure,这样就只能通过安全通道(如HTTPS)访问Cookie对象 |
|
session |
boolean |
可选 |
是否为Session级别的Cookie对象 |
|
storeId |
string |
可选 |
包含该Cookie对象的CookieStore的ID |
- 设置Cookie对象
chrome.cookies.set(object details, function(Cookie cookie) {...})
details对象的属性如下:
|
属性名 |
类型 |
必选/可选 |
注释 |
|
url |
string |
必选 |
访问Cookie对象的请求的URI,影响domain和path |
|
name |
string |
可选 |
Cookie对象的名字 |
|
value |
string |
可选 |
Cookie对象的值 |
|
domain |
string |
可选 |
Cookie对象适用的域 |
|
path |
string |
可选 |
Cookie对象适用的URL路径 |
|
secure |
boolean |
可选 |
Cookie对象是否被标记为Secure,这样就只能通过安全通道(如HTTPS)访问Cookie对象 |
|
httpOnly |
boolean |
可选 |
Cookie对象是否被标记为HttpOnly,这样客户端脚本就无法访问Cookie对象 |
|
expirationDate |
double |
可选 |
Cookie对象的过期时间,单位s Session级别的Cookie对象没有该属性,因为会话结束即过期 |
|
storeId |
string |
可选 |
包含该Cookie对象的CookieStore的ID |
- 根据名字删除Cookie对象
chrome.cookies.remove(object details, function(object details) {...})
details对象的属性如下:
|
属性名 |
类型 |
注释 |
|
url |
string |
要删除的Cookie对象所关联的URL |
|
name |
string |
要删除的Cookie对象的名字 |
|
storeId |
string |
要删除的Cookie对象的CookieStore的ID |
- 获取所有的cookie仓库对象
chrome.cookies.getAllCookieStores(function(array of CookieStore cookieStores) {...})
- 监听Cookie对象的变化
chrome.cookies.onChanged.addListener(function(object changeInfo) {...})
如果Cookie对象的值被修改或删除,则发出该事件。changeInfo对象的属性如下:
|
属性名 |
类型 |
注释 |
|
removed |
boolean |
Cookie对象是否被删除 |
|
cookie |
chrome.cookies.Cookie |
发生变化的Cookie对象 |
|
cause |
chrome.cookies.OnChangedCause |
导致Cookie对象变化的原因 |
Chrome浏览器扩展开发系列之八:Chrome扩展的数据存储的更多相关文章
- Chrome浏览器扩展开发系列之十四
Chrome浏览器扩展开发系列之十四:本地消息机制Native messaging 时间:2015-10-08 16:17:59 阅读:1361 评论:0 收藏:0 ...
- Chrome浏览器扩展开发系列之十四:本地消息机制Native messagin
Chrome浏览器扩展开发系列之十四:本地消息机制Native messaging 2016-11-24 09:36 114人阅读 评论(0) 收藏 举报 分类: PPAPI(27) 通过将浏览器 ...
- Chrome浏览器扩展开发系列之十六:扩展中可用的Chrome浏览器API
除了Chrome浏览器支持的chrome.* API之外,Chrome浏览器扩展还可以使用Chrome浏览器为Web页面或Chrome app提供的APIs.对于Chrome浏览器2支持的API,还可 ...
- Chrome浏览器扩展开发系列之一:初识Google Chrome扩展
1. Google Chrome扩展简介 Google Chrome扩展是一种软件,以增强Chrome浏览器的功能. Google Chrome扩展使用HTML.JavaScript.CS ...
- Chrome扩展开发之二——Chrome扩展中脚本的运行机制和通信方式
目录: 0.Chrome扩展开发(Gmail附件管理助手)系列之〇——概述 1.Chrome扩展开发之一——Chrome扩展的文件结构 2.Chrome扩展开发之二——Chrome扩展中脚本的运行机制 ...
- EXT.NET高效开发(三)——使用Chrome浏览器的开发人员工具
这篇帖子老少皆宜,不分男女,不分种族,不分职业.俗话说:“磨刀不误砍柴工”.掌握一些开发工具的使用,对自己帮助是很大的(无论是用于分析问题,还是提高生产力).本篇就讲述如何利用Chrome浏览器(这里 ...
- Spring Boot干货系列:(八)数据存储篇-SQL关系型数据库之JdbcTemplate的使用
Spring Boot干货系列:(八)数据存储篇-SQL关系型数据库之JdbcTemplate的使用 原创 2017-04-13 嘟嘟MD 嘟爷java超神学堂 前言 前面几章介绍了一些基础,但都是静 ...
- Node.js 从零开发 web server博客项目[数据存储]
web server博客项目 Node.js 从零开发 web server博客项目[项目介绍] Node.js 从零开发 web server博客项目[接口] Node.js 从零开发 web se ...
- Chrome浏览器扩展开发系列之十九:扩展开发示例
翻译总结了这么多的官网内容,下面以一款博主开发的“沪深股票价格变化实时追踪提醒”软件为例,介绍Chrome浏览器扩展程序的开发,开发环境为Eclipse IDE+Chrome Browser. “沪深 ...
随机推荐
- mysql数据库小常识
什么是数据库? 计算机处理和存储的一切信息都是数据. 计算机系统中一种用于存储数据的程序. 一种:计算机系统中有很多种能够存取数据的程序. 他们各有特长和长处,有自己的适用范围. 存取:能够保存数据避 ...
- laravel5.2之logout注销账号无效
问题描述:laravel5.2的框架,使用框架auth用户认证后,进行账号注销退出的时候,无法实现. 只有清除浏览器缓存,才能实现账号退出. 解决办法: 改变路由 Route::get('auth/l ...
- 根据源码用HttpServletRequest获取MultipartFile的问题
问题 由于某些原因,现在需要这样的一个文件上传接口,这个接口type(String)是必传参数,photoFile(MultipartFile)是非必传参数,即一般情况下需要接受两个参数,分别为pho ...
- 数据库插入数据失败,log提示不能将值 NULL 插入列 'id'
已经记不住具体的log信息了,意思就是ID如果没有设置为自增长的情况下就不能插入数据,而建表时ID字段是设置为"not null",所以就不能顺利插入数据. 解决方法有两种: ①建 ...
- TypeScript 零基础入门
前言 2015 年末看过一篇文章<ES2015 & babel 实战:开发 npm 模块>,那时刚接触 ES6 不久,发觉新的 ES6 语法大大简化了 JavaScript 程序的 ...
- Java Web入门学习(四)Eclipse与Maven、Tomcat整合配置
Java Web学习(四)Eclipse与Maven整合配置 一.准备工作 1.Tomcat 8.5.15 2.Maven3.5 3.Eclipse Neon.3 Release (4.6.3) 二. ...
- 关于AD9516芯片的硬件设计和FPGA程序编写心得
最近在做一个项目,其中有涉及时钟芯片AD9516的硬件设计和软件编程,有些使用心得,供大家参考讨论. AD9516,这是一个由ADI公司设计的14路输出时钟发生器,具有亚皮秒级抖动性能,还配有片内集成 ...
- Coursera 机器学习笔记(一)
主要是第一二周内容 机器学习概要 机器学习是什么? 生活在信息时代的我们,其实时时刻刻都离不开机器学习算法.比如日常使用的搜索引擎就涉及到很多学习算法. Arthur Samuel 给出第一个定义.他 ...
- EF Core学习Code First
下面通过实例来学习EF Core Code First,也就是通过EF Core迁移来完成从模型生成数据库. 本实例使用EntityFrameworkCore SQLite 数据库进行介绍,大家也可以 ...
- 在firefox的flashgot中配置各种下载器
一.在firefox中安装flashgot下载管理器 flashgot是firefox的一个扩展,在联网的情况下,可以在firefox中的附加组件中搜索flashgot,然后安装. 二.在flashg ...