如何实现不同域名之间共享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的值并输出。


关于我们 加入我们 广告服务 网站地图

All Rights Reserved, Copyright 2004-2020 www.ctocio.com.cn

如有意见请与我们联系 邮箱:5 53 13 8 [email protected]

豫ICP备20005723号-1    IT专家网 版权所有 

营业执照