`
lucifinilhades
  • 浏览: 86804 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

HTML5 跨文档消息传输

阅读更多

基本介绍

HTML5提供了在网页文档之间互相接收与发送信息的功能。使用这个功能,只要获取到网页所在窗口对象的实例,不仅同源(域+端口号)的Web网页之间可以互相通信,甚至可以实现跨域通信。

要想授受从其他窗口发送来的信息,必须对窗口对象的message事件进行监听,代码如下:

window.addEventListener("message", function(event) {
    // 处理程序代码
}, false);

使用window对象的postMessage()方法向其他窗口发送消息,该方法的定义如下:

otherwindow.postMessage(message, targetOrigin);

该方法使用两个参数:第一个参数为所发送的消息文本,但也可以是任何JavaScript对象(通过JSON转换对象为文本);第二个参数为接收消息的对象窗口的URL地址,可以在URL地址字符串中使用通配符“*”指定全部地址,不过建议使用准确的URL地址。otherwindow为要发送窗口对象的引用,可以通过window.open()方法返回该对象,或通过对window.frames数组指定序号(index)或名字的方式来返回单个frame所属性的窗口对象。

跨域示例

主页面向iframe子页面发送消息,iframe子页面显示接收到的消息,然后向主页面返回消息,最后主页面接收消息并使用提示框显示该消息。

主页面代码如下:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8"/>
		<title>跨文档消息传输示例主文档</title>
		<script type="text/javascript" src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
		<script type="text/javascript">
$(function() {
	// 监听message事件。
	window.addEventListener("message", function(event) {
		// 忽略指定URL之外的页面发送的消息。
		if(event.origin != "http://www.blue-butterfly.net") return;
		alert(event.data); // 显示消息。
	}, false);
	
	$("#iframeContent").load(function(event) {
	        // 向子页面发送消息
		this[0].postMessage("Hello", "http://www.blue-butterfly.net/test/");
	});
});
		</script>
	</head>
	<body>
		<header>
			<h1>跨域通信示例</h1>
		</header>
		<iframe id="iframeContent" width="400" src="http://www.blue-butterfly.net/test/"></iframe>
	</body>
</html>

子页面中的代码如下:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8"/>
		<script type="text/javascript" src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
		<script type="text/javascript">
$(function() {
	window.addEventListener("message", function(event) {
		if(event.origin != "http://Lulingniu") return;
		$("#console").append(event.origin).append("传来的消息:").append(event.data);
                // 向主页面发送消息。
		event.source.postMessage("Hello, there is :" + this.location, event.origin);
	}, false);
});
		</script>
	</head>
	<body>
		<p>这是iframe中的内容。</p>
		<div id="console"></div>
	</body>
</html>
  • 通过对window对象的message事件进行监听,可以接收消息。
  • 通过访问message事件的origin属性,可以获取消息的发送源(本例中主页面的发送源为“http://Lulingniu”,子页面的发送源为“http://www.blue-butterfly.net”)。注意:发送源与网站的URL地址不是一个概念,发送源只包括域名与端口号,为了不接收其他源恶意发送过来的消息,最好对发送源做检查。
  • 通过访问message事件的data属性,可以取得消息内容(可以是任何JavaScript对象,使用JSON)。
  • 使用postMessage()方法发送消息。
  • 通过访问message事件的source属性,可以获取消息发送源的窗口的代理对象。
分享到:
评论

相关推荐

    html5 跨文档消息传输示例探讨

    HTML5的跨文档消息传输(Cross-document messaging)是一种在不同源的浏览器窗口之间安全地交换信息的方法。这个功能主要是为了处理跨域通信的问题,因为出于安全考虑,浏览器通常禁止不同源的网页之间直接共享数据...

    H5 蓝牙模块数据传输demo

    在现代移动应用开发中,H5(HTML5)技术已经成为不可或缺的一部分,特别是在跨平台和物联网(IoT)领域。"H5 蓝牙模块数据传输demo" 是一个基于Hbuilder开发的示例项目,专注于BLE(低功耗蓝牙)的数据通信功能。BLE是...

    跨平台跨语言API文档编写工具.rar(附带教程)

    在标签“跨平台跨语言API文档编写工具.rar”中,“.rar”是文件的压缩格式,它通常用于将多个文件打包成一个文件以便于存储和传输。在这个上下文中,这个标签可能是在强调这个压缩包包含的工具是跨平台的,并且专门...

    HTML页面嵌入WORD编辑文档

    在IT领域,HTML页面嵌入Word编辑文档是一种常见的需求,特别是在构建富文本编辑器或在线文档处理系统时。本主题将深入探讨如何实现这一功能,以及相关技术的应用和原理。 HTML(HyperText Markup Language)是网页...

    html XML开发文档

    这使得XML成为编写结构化、跨平台的开发文档的理想选择,如软件接口定义、数据交换规范等。 XML SDK(Software Development Kit)可能包含一组工具和库,帮助开发者解析、创建、修改XML文档。这些工具可能包括解析...

    HTML5程序设计-3期(KC014) KC014050000009 单元设计_单元9 HTML5 通信和多线程..doc

    首先,跨文档消息传输是HTML5中解决不同源(如不同域名、不同端口)网页间通信问题的关键技术。学生需要理解其基本概念,包括如何实现不同页面、不同端口、不同域之间的消息传递。这通常涉及使用`postMessage`和`...

    HTML5学习资料大全(教程,帮助文档,实例源码)

    “communication”可能涵盖HTML5的跨文档消息传递(Cross-document messaging)和WebRTC技术。前者允许不同源的页面之间进行通信,而后者则提供了浏览器之间的实时通信能力,支持音频、视频的传输,无需插件,非常...

    JavaScript实现的双向跨域插件分享

    为了解决跨域请求的问题,HTML5引入了跨文档消息传输(Cross-Origin Communication)的功能。这一功能允许不同源之间的页面进行通信,主要通过两个方法实现:`postMessage`和`onmessage`事件处理器。 - `post...

    HTML5开发精要与实例详解(完整版源代码含说明文档)

    第7章用单点登录和获取批量数据这2个案例讲解了html 5中的跨文档的消息传输技术;第8章用2个案例讲解了如何利用web workers实现多线程处理;第9章用1个案例讲解了如何利用geolocation api来获取地理位置信息;第10~...

    HBuilder实现蓝牙通讯 - 亲测可用html5-bluetooth-demo-HBuilderX

    标签“BlueTo 蓝牙 蓝牙传输源码 H5+Blu”进一步细化了主题,其中“BlueTo”可能是对蓝牙(Bluetooth)的简称,“H5+Blu”表明是HTML5与蓝牙技术的结合,而“蓝牙传输源码”则意味着提供了实现蓝牙通信的具体代码。...

    HTML5手册.zip

    HTML5的核心目标是提升用户体验,简化开发流程,并实现跨平台兼容性。它的新特性包括: 1. **语义化标签**:如, , , , 等,这些标签提供了更强的内容结构,帮助搜索引擎更好地理解和索引网页内容。 2. **离线存储*...

    PDF文档转换成word,html,swf格式软件

    PDF格式因其跨平台兼容性和内容保真性而被广泛使用,但有时我们需要将其转换为更便于编辑的Word文档,或者为了在网络上传输和展示,转换成HTML网页或SWF动画。以下将详细介绍这些转换过程和相关知识点: 1. **PDF转...

    HTML5Speedtest轻量级的HTML5网速测试工具

    总的来说,HTML5 Speedtest是一个体现HTML5强大功能的实例,它展示了如何利用现代Web技术解决传统问题,并提供了一个无插件、跨平台的网络速度测试解决方案。通过深入研究和实践,我们可以进一步提升我们的前端开发...

    flask官方文档html版

    - Flask-Compress可以自动压缩响应内容,提高传输效率。 5. **命令行接口(CLI)** - Flask提供了`flask`命令行工具,可以用于运行应用、初始化数据库等操作。 6. **测试(Testing)** - Flask自带测试客户端,...

    HTML5程序设计(第2版).[荷]Peter Lubbers(带详细书签).pdf

    6.1.2 跨文档消息通信的浏览器支持情况 122 6.1.3 使用postMessage API 123 6.1.4 使用postMessage API创建应用 124 6.2 XMLHttpRequest Level 2 128 6.2.1 跨源XMLHttpRequest 129 6.2.2 进度事件 130 6.2.3...

    Java API文档 中文网页版

    HTML格式的优点是跨平台且易于阅读,同时支持链接跳转,使得在文档中查找相关类和方法变得简单快捷。 在使用Java API文档时,开发者通常会关注以下几个方面: 1. 类(Class):了解类的职责、构造器、属性和方法。...

    Hprose_for_HTML5用户手册.pdf

    《Hprose_for_HTML5用户手册》是针对在HTML5环境下使用Hprose这一轻量级、跨语言、跨平台的RPC(Remote Procedure Call)框架的详细指南。Hprose是一个强大的开源远程调用解决方案,它支持多种编程语言,包括...

    HTML5秘籍.pdf

    11. 通信API: HTML5引入了跨文档消息传输(Cross-Origin Resource Sharing, CORS),允许文档在不同源之间进行交互式通信。 12. 兼容性与性能: HTML5在浏览器兼容性上做了一些优化。另外,浏览器性能在HTML5时代也...

    HTML 文档 (.xml)解读

    HTML文档(.xml)是一种基于XML(Extensible Markup Language)标准的数据格式,它主要用于存储和传输结构化数据。XML的设计宗旨是传输和存储数据,而不是显示数据,这与HTML(HyperText Markup Language)的主要...

Global site tag (gtag.js) - Google Analytics