HTML5的postMessage机制是客户端最直接的中档传输方法,一般用在iframe中父页与子页之间的客户端跨域通信。

浏览器支持情况:Chrome 2.0+、Internet Explorer 8.0+, Firefox 3.0+, Opera 9.6+, 和 Safari 4.0+ 。 Facebook已经使用了这个功能,用postMessage支持基于web的实时消息传递。

用法:otherWindow.postMessage(message, targetOrigin)

otherWindow: 对接收信息页面的window的引用。可以是页面中iframe的contentWindow属性;window.open的返回值;通过name或下标从window.frames取到的值。

message: 所要发送的数据,string类型。

targetOrigin: 用于限制otherWindow,“*”表示不作限制

下面是一个基于postMessage的简单聊天实例:

http://www.evil.com:8081/langtao/evil.html页面代码:

<iframe id="ifr" src="http://www.foo.com:8081/langtao/foo.html" width="500" height="300"></iframe>
<div id="msgbox">
</div>
<input type="text" id="msg" />
<input type="button" value="发送" id="btn"/>
<script type="text/javascript">
window.onload = function() {
document.getElementById('btn').onclick=function(){
var ifr = document.getElementById('ifr');
var targetOrigin = 'http://www.foo.com:8081/langtao/'; // 若写成http://www.foo.com:8081/langtao/foo.html'效果一样
var msg=document.getElementById('msg').value;
ifr.contentWindow.postMessage(msg,targetOrigin); var c=document.createElement('div');
c.innerHTML="你说:"+msg;
msgbox.appendChild(c);
}
};
window.addEventListener('message', function(e){
// 通过origin属性判断消息来源地址
if (e.origin == 'http://www.foo.com:8081') {//不可以设置为'http://www.foo.com:8081/'
var c=document.createElement('div');
c.innerHTML="来自"+e.origin+"的消息:"+e.data;
msgbox.appendChild(c);
}
}, false);
</script>

http://www.foo.com:8081/langtao/foo.html页面代码:

<div id="msgbox">
</div>
<input type="text" id="msg" />
<input type="button" value="发送" id="btn"/>
<script type="text/javascript">
var msgbox=document.getElementById('msgbox');
window.addEventListener('message', function(e){
if (e.origin == 'http://www.evil.com:8081') {
var c=document.createElement('div');
c.innerHTML="来自"+e.origin+"的消息:"+e.data;
msgbox.appendChild(c);
}
}, false);
document.getElementById('btn').onclick=function(){
var targetOrigin = 'http://www.evil.com:8081/langtao/';
var msg=document.getElementById('msg').value;
window.top.postMessage(msg, targetOrigin); var c=document.createElement('div');
c.innerHTML="你说:"+msg;
msgbox.appendChild(c);
}
</script>

效果图:

aaarticlea/png;base64,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" alt="" />

从代码中可以看到,postMessage机制,这种跨域需要双方默契配合,且可以在客户端通过orgin进行判断请求的来源是否合法。

跨域(五)——postMessage的更多相关文章

  1. 跨域传输信息postMessage

    widnow.postMessage()方法允许安全的跨域传输. Syntax otherWindow.postMessage(message, targetOrigin, [transfer]); ...

  2. JavaScript 跨域:window.postMessage 实现跨域通信

    JavaScript 跨域方式实现方式有很多,之前,一篇文章中提到了 JSONP 形式实现跨域.本文将介绍 HTML5 新增的 api 实现跨域:window.postMessage . 1 othe ...

  3. 详解JS跨域问题

    什么是跨域? 概念:只要协议.域名.端口有任何一个不同,都被当作是不同的域.             JavaScript   1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

  4. 【前端】【转】JS跨域问题总结

    详情见原博客:详解js跨域问题 概念:只要协议.域名.端口有任何一个不同,都被当作是不同的域. 跨域资源共享(CORS) CORS(Cross-Origin Resource Sharing)跨域资源 ...

  5. js跨域问题解决方案

     跨域:当协议.域名.端口号任何一个不相同时,叫称为跨域.   HTML5  CORS(cross-origin-resource-sharing)跨域资源共享: 原理:当需要访问跨域的资源时,可以通 ...

  6. 详解js跨域

    什么是跨域? 概念:只要协议.域名.端口有任何一个不同,都被当作是不同的域. 对于端口和协议的不同,只能通过后台来解决.URL 说明 是否允许通信 http://www.a.com/a.js http ...

  7. JS中的跨域问题

    一.什么是跨域? 1.定义:跨域是指从一个域名的网页去请求另一个域名的资源.比如从www.baidu.com 页面去请求 www.google.com 的资源.但是一般情况下不能这么做,它是由浏览器的 ...

  8. js跨域解决方式

    什么是跨域? 概念:仅仅要协议.域名.port有不论什么一个不同,都被当作是不同的域.(所谓同源是指,域名.协议,port同样.),对于port和协议的不同,仅仅能通过后台来解决. URL 说明 是否 ...

  9. 在javascript中的跨域解决

    跨域产生的原因 跨域是由浏览器的同源策略引起的,即不同源(协议,域名,端口中其中有一个不同)的js是不能读取对方的资源的.当要网站中的js要请求其他网站的数据时就会产生跨域问题,就像下面这样,浏览器会 ...

  10. 一个iOS程序员眼中的跨域问题

    摘要: 跨域问题是web开发领域一个常见的问题,相信每个web开发者都遇到"跨域"的问题 最近公司的iOS开发任务比较少,所以自己最近开始了Web开发的任务,在用H5做了很多页面, ...

随机推荐

  1. 在线学习和在线凸优化(online learning and online convex optimization)—在线分类问题2

    紧接上文,我们讲述在线分类问题 令,为0-1损失,我们做出如下的简化假设: 学习者的目标是相对于hypotheses set: H具有low regret,其中H中的每个函数是从到{0,1}的映射,并 ...

  2. jdbc连接池&改进dbUtil成C3P0Util

    一.jdbc连接池 1.连接池的存在理由   前面介绍的dbUtils工具类虽然实现了一个对jdbc的简单封装.但它依旧采取从驱动管理获取连接 (DriverManager.getConnection ...

  3. echarts学习之——电力迁徙图

    今天主要就是在搞echarts,我们都知道他为我们提供了丰富的api方法,使我们能够迅速的搭建图标.同时他里面还有许多的案例, 其中就有这么一个国内航线模拟迁徙的地图,如下所示: 而我们通常因为各种需 ...

  4. for循环循环时间

    )) { Console.WriteLine(dt); } ("2011-5-5")       按需求定义 AddDays函数,   一天一天的增长

  5. Ramdisk虚拟内存盘,Swap分区

    虚拟内存盘是通过软件将一部分内存(RAM)模拟为硬盘来使用的一种技术.相对于直接的硬盘文件访问来说,这种技术可以极大的提高在其上进行的文件访问的速度.但是RAM的易失性也意味着当关闭电源后这部分数据将 ...

  6. solr 忽略大小写

    1.types标签下加入如下fieldType <fieldType name="str_lower" class="solr.TextField" so ...

  7. ES6的学习记录

    1.let命令: 基本用法: ES6新增了let命令,用来声明变量.用法类似于var,但是所声明的变量只在let命令所在的代码块内有效. { let a = 10; var b = 1; } cons ...

  8. Uncaught (in promise) DOMException: Failed to execute 'open' on 'XMLHttpRequest': Invalid URL

    解决方案:url前面一定要加http://

  9. 动态参数(*args,**kwargs),命名空间和作用域,global和nonlocal,函数的嵌套

    1. 动态参数 位置参数的动态参数: *args 关键字参数的动态参数 : **kwargs 顺序: 位置,*args,默认值,**kwargs 在形参上*聚合, **聚合 在实参上*打散, **打散 ...

  10. Linux常用操作分享

    Java开发经常遇到的linux相关操作 1.常用的上传下载(Xshell5) 1).get 从远程服务器上下载一个文件存放到本地,如下: 先通过lcd切换到本地那个目录下,然后通过get file ...