<sub id="s17i1"><b id="s17i1"></b></sub>

  1. <dl id="s17i1"><font id="s17i1"><nobr id="s17i1"></nobr></font></dl>

  2. <output id="s17i1"></output>

    1. <output id="s17i1"></output>
      <li id="s17i1"></li>
    2. 什么是jsonp

      什么是jsonp,jsonp是什么,jsonp如何使用

      首先先知道

      1. jsonp的核心原理就是目标页面回调本地页面的方法,并带入参数
      2. 我们常用的动态页面有jsp,php,aspx

      为什么需要JSONP?

      由于浏览器安全限制,数据是不可以直接跨域(包括不同的根域名、二级域名、或不同的端口)请求的,除非目标域名授权你可以访问。比如设置crossdomain.xml 或在http头部里授权

      但是crossdomain.xml会?#24066;?#35774;置的网站访问所有的数据,而头?#21487;?#32622;?#22336;?#24120;麻?#22330;?

      所?#38053;?#20197;在你授权的数据返回里设置jsonp来让该接口?#24066;?#25152;有的调用者获取数据。

      JSONP的原理

      jsonp是使用方法回调的原理.

      在网页里,你如果引入其他网页的js,那这个页面的js是可以调用你网页的代码的

      直接请求js 和 请求的动态页面(jsp,php,aspx)里输出的javascript代码 效果一样

      function showjson(json){
      	alert(json.url);
      }
      
      如果引用的js或动态页面里有 showjson({"url":"http://www.nxtru.icu"});这行代码的话,那就会弹出 http://www.nxtru.icu

      jsonp的第一?#22336;?#24335;,将目标作为js形式加载过来,尽管其实对方是一个php

      下面我们在这个页面里来请求http://www.ibilibili.com/static/js/forbejson/userinfo.php页面的数据,这个php页面数据会有回调函数showjson,来调用我们这个bejson页面里的 showjson方法 并将一个json传入
      < ?php 
      	//这里是php页面里,回调showjson方法,这里的方法必须和上面定义的本地页面中的回调方法一致
      	echo 'showjson({"url":"http://www.nxtru.icu"})';
      ?>
      	
      $("#getuserp").click(function(){
      	$.getScript("http://www.nxtru.icu/test/userinfop.php");
      });
      	

      那如果我们抓包后就会看到(如上图),点击按钮后发起了一个http请求,

      请求了//www.nxtru.icu/test/userinfop.php页面,

      页面里输出了 showjson({"url":"http://www.nxtru.icu"}) ,

      因为是以javascript文件形式加载过来 ,所以他会对本地页面showjson发起回调(看绿色箭头),并传入json参数(看红色箭头),所以就会弹出了json中的url

      直接用jquery的ajax来请求jsonp

      感谢葫芦指出代码错误,并提供正确代码

       $.ajax({
           url:'//www.nxtru.icu/test/userinfop.php',
           type:"GET",
                  dataType:"jsonp",
                  jsonp: false, 
                  jsonpCallback: "showjson", //这里的值需要和回调函数名一样
                  success:function(data){
                      console.log("Script loaded and executed.");
                  },
                  error:function (textStatus) { //请求失败后调用的函数
                      console.log(JSON.stringify(textStatus));
                  }
      });			
      		

      重庆时时开奖结果记录

      <sub id="s17i1"><b id="s17i1"></b></sub>

      1. <dl id="s17i1"><font id="s17i1"><nobr id="s17i1"></nobr></font></dl>

      2. <output id="s17i1"></output>

        1. <output id="s17i1"></output>
          <li id="s17i1"></li>
        2. <sub id="s17i1"><b id="s17i1"></b></sub>

          1. <dl id="s17i1"><font id="s17i1"><nobr id="s17i1"></nobr></font></dl>

          2. <output id="s17i1"></output>

            1. <output id="s17i1"></output>
              <li id="s17i1"></li>