首页 资讯频道 互联频道 智能频道 网络 数据频道 安全频道 服务器频道 存储频道

如何实现不同域名之间共享localStorage/sessionStorage

2020-02-04 10:22:29 来源 : 快资讯

两个不同的域名的localStorage不能直接互相访问。那么如何在domain2.com中如何调用domain1.com的localStorage?

实现原理

1.在domain2.com的页面中,在页面中嵌入一个src为domain1.com的iframe,此时这个iframe里可以调用domain1.com的localStorage。2.用postMessage方法实现页面与iframe之间的通信。综合1、2便可以实现domain2.com中如何调用domain1.com的localStorage。

优化iframe

我们可以在domian1.com中写一个专门负责共享localStorage的页面,例如叫做page1.html,这样可以防止无用的资源加载到iframe中。

示例

以在domain2.com中读取domain1.com中的localStorage都item1为例,写同理:domain1.com中page1.html,监听doamin2.com通过postMessage传来的信息,读取localStorage,然后再使用postMessage方法传给doamin2.com的接收者。

This page is for sharing localstorage.

在domain2.com的页面中加入一个src为domain1.com/page1.html隐藏的iframe。

在domain2.com的页面中加入下面script标签。在页面加载完毕时通过postMessage告诉iframe中监听者,读取item1。监听domain1.com传回的item1的值并输出。

相关文章

最近更新