JSONP -- 跨域数据交互协议

1、概念javascript

①传统Ajax:交互的数据格式——自定义字符串或XML描述;html

    跨域——经过服务器端代理解决。java

②现在最优方案:使用JSON格式来传输数据,使用JSONP来跨域。json

③JSON:一种数据交换格式。基于纯文本、被原生JS支持。跨域

      格式:两种数据类型描述符:大括号{ }、方括号[ ]。分隔符逗号、映射符冒号、定义符双引好。服务器

④JSONP:一种跨域数据交互协议,非官方。app

  一、Web页面调用js文件,可跨域。扩展:但凡是有src属性的标签都具备跨域能力。函数

  二、跨域服务器 动态生成数据 并存入js文件(一般json后缀),供客户端 调用。post

  三、为了便于客户端使用数据,造成一个非正式传输协议,称为JSONP。该协议重点是容许用户传递一个callback参数给服务器,而后服务器返回数据时 将此callback参数做为函数名包裹住JSON数据,使得客户端能够随意定制本身的函数来自动处理返回数据。jsonp

 

 

 2、JSONP实现

实例1——客户端单方面接收:

①客户端——在客户端设置建立一个函数对象,名称可为callFunc,用于接收服务器的js数据和对其进行处理。
  js数据中的核心是:调用callFunc函数的同时附带着参数,此参数即data对象的值。

<script type="text/javascript">
    var callFunc = function(data){
        alert('远程js文件传来的数据:' + data.result);//data为服务器端的JSON数据对象。
    };
</script>
<script type="text/javascript" src="http://其余域的js文件.com/remote.js"></script>

 

②服务器端——直接调用客户端js中的函数,并传入数据。

callFunc({"result":"value1"});

 

实例2——客户端向服务器传送 指定函数名,服务器端接收该函数名 并调用对应函数 将数据以参数形式传入。

复制代码
<script type="text/javascript">
    // 获得航班信息查询结果后的回调函数
    var flightHandler = function(data){
        alert('你查询的航班结果是:票价 ' + data.price + ' 元,' + '余票 ' + data.tickets + ' 张。');
    };
    // 动态添加连接服务器js文件的script。
  // 在url地址中传递了一个code参数匹配JSON数据中的某个key,callback参数则告诉服务器:本地回调函数名为callFuncName。
var url = "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998&callback=callFuncName"; var script = document.createElement('script'); script.setAttribute('src', url); // 将script元素在网页加载时插入head头部 document.getElementsByTagName('head')[0].appendChild(script); </script>
复制代码

总结:实现的代码并不复杂,但在实现Ajax跨域、frameset/iframe跨域等倒是效率颇高的。

 

 

出处:http://www.cnblogs.com/slowsoul/archive/2013/02/14/2910661.html

相关文章
相关标签/搜索