欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JSONP 的原理、理解 与 实例分析

程序员文章站 2022-06-17 14:35:29
本文实例讲述了jsonp 的原理、理解 与 实例。分享给大家供大家参考,具体如下:1.什么是jsonp1.1 同源策略浏览器同源策略的限制,xmlhttprequest只允许请求当前源(相同域名、协议...

本文实例讲述了jsonp 的原理、理解 与 实例。分享给大家供大家参考,具体如下:

1.什么是jsonp

1.1 同源策略 

浏览器同源策略的限制,xmlhttprequest只允许请求当前源(相同域名、协议、端口)的资源。

-1)jsonp只支持get请求

-2)不受同源策略限制 ,兼容性好 不需要xmlhttprequest(activex)支持,通过js回调函数返回结果

-3)不能解决 不同域的两个页面之间js调用的问题

2. jsonp 原理

动态添加一个script标签,get链接上发送回调函数名称 传给服务器 服务器获取回调函数名称 返回这个函数名称的js函数(拼装函数) json数据作为函数的实际参数传入 返回的数据是js函数  在前端调用回调函数( json数据传入) 执行回调函数

3.实例

先来说说 服务端应该返回的数据形式 如下所示 用的php  thinphp框架编写的 访问url 是 

http://91hx.xicp.cn:8989/service/validata/testjsonp?callback=jsonpcallback callback后面的名字要传给服务器的 后端拼装成一个js回调函数 这样前台json数据就作为回调函数的参数传入 获取到数据了

 public function testjsonp(){
    $jsonname =i('get.callback');//获取url上的callback名称 也就是获取jsonpcallback

    $a = [name=>'张三',sex=>'男',msg=>'返回成功!'];// 一个数组数据
    $json = json_encode($a);// 转成json数据

    echo $jsonname.'('.$json.');';//正确的格式应该是这样 jsonpcallback({"name":"\u5f20\u4e09","sex":"\u7537","msg":"\u8fd4\u56de\u6210\u529f\uff01"}); 不要忘记分号; 这样返回的才是一个js函数 前台肯定有这个函数名字才行

}

tip: 上面例子 $a = array( "msg" => "返回成功!")

前台 访问url http://localhost:63343/h5/jsonp.html 动态添加一个script标签 src里 调用回调函数 jsonpcallback() . ?callback=jsonpcallback名字随便起 后端获取的就是jsonpcallback这个名字而已 

<!doctype html>
<html>
<head lang="en">
  <meta charset="utf-8">
  <title></title>
</head>
<body>

<script type="text/javascript">

  function jsonpcallback(date){
    console.log(date);
    alert(date);
    alert(date.msg);
  }
  var script =document.createelement('script');
  script.src='http://91hx.xicp.cn:8989/service/validata/testjsonp?callback=jsonpcallback';
  document.body.insertbefore(script,document.body.firstchild);


</script>

</body>
</html>

 我们可以在浏览器里 这里我用的谷歌直接查看 数据是否访问正确 切换到network标签下 可以看到生成的访问地址 点击然后

JSONP 的原理、理解 与 实例分析 

这下面的图 点击一下左侧链接   切换到response就可以看到响应的数据了 跟前端写的函数名要一致 里面的json数据就是 那个函数的参数 传入 别忘记有分号;

JSONP 的原理、理解 与 实例分析

前端我们已经console.log 数据了 也可以查看 切换到console标签下

JSONP 的原理、理解 与 实例分析