亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript實(shí)現(xiàn)跨域的方法匯總

 更新時(shí)間:2015年06月25日 11:54:20   投稿:hebedich  
這篇文章主要給大家匯總介紹了javascript實(shí)現(xiàn)跨域的方法的相關(guān)資料,需要的朋友可以參考下

由于同源策略的限制,XMLHttpRequest只允許請(qǐng)求當(dāng)前源(包含域名、協(xié)議、端口)的資源。

json與jsonp的區(qū)別:

    JSON是一種數(shù)據(jù)交換格式,而JSONP是一種依靠開(kāi)發(fā)人員創(chuàng)造出的一種非官方跨域數(shù)據(jù)交互協(xié)議。

script標(biāo)簽經(jīng)常被用來(lái)加載不同域下的資源,可以繞過(guò)同源策略。(有src屬性的都可以獲取異域文件)。
如果請(qǐng)求的這個(gè)遠(yuǎn)程數(shù)據(jù)本身就是一段可執(zhí)行的js,那么這些js會(huì)被執(zhí)行(相當(dāng)于eval)。

方法一:

利用script標(biāo)簽請(qǐng)求(<script src="http://....jsp?callback=回調(diào)函數(shù)名"></script>)
在使用script標(biāo)簽請(qǐng)求前,先進(jìn)行回調(diào)函數(shù)的申明調(diào)用,

  <script>
    function 回調(diào)函數(shù)名(data數(shù)據(jù)){  。。。。 }
  </script>
  <script src="http://....jsp?callback=回調(diào)函數(shù)名"></script>

使用JSON來(lái)傳遞javascript對(duì)象是一種最簡(jiǎn)單的方式了,這樣的跨域通訊方式稱(chēng)為JSONP。
   
    遠(yuǎn)程服務(wù)器拼湊字符串:
        回調(diào)函數(shù)名( {"name1":"data1","name2","data2"} )
    這種以后臺(tái)拼湊json數(shù)據(jù),利用回調(diào)函數(shù)傳參的形式返回給客戶(hù)端
    (可以直接調(diào)用相當(dāng)于已經(jīng)將獲取的字符串進(jìn)行eval了處理)
    例如:function databack(data){ alert(data.name1) }  // 會(huì)輸出顯示"data1"

方法二:

jquery實(shí)現(xiàn)異域加載方法更為簡(jiǎn)單(與ajax異步請(qǐng)求方式相同)

  $.ajax({
    type : "get",
    dataType:"json",
    success : function(data){ alert(data.name1) };
  })

    或者簡(jiǎn)寫(xiě)形式
    var url = "http://.....jsp?callback=?"; // 在jquery中此處的callback值可以為任意,因?yàn)?/p>

jquery進(jìn)行處理后都是利用success回調(diào)函數(shù)進(jìn)行數(shù)據(jù)的接受;
    $.getJSON( url, function(data){ alert(data.name1) });

方法三:

ajax跨域之服務(wù)端代理
    在同源的后臺(tái)設(shè)置一個(gè)代理程序(proxy.jsp...);在服務(wù)器端與異域的服務(wù)器交互。
   
    jquery前臺(tái)傳輸數(shù)據(jù):
        例如:

    $.get(
      'http://。。。.jsp',  // 代理程序地址
      {
         name1 : "data1",
         name2 : "data2"
       },
       function(data){
      if(data == 1) alert('發(fā)送成功!');
       }
    );
  

    后臺(tái)數(shù)據(jù)的處理 :

    String data1 = request.getParameter("name1");
    ........
    // 此處的url為另一域下的地址并帶有參數(shù)
    String url = "http://.....com/.../sss.jsp?" + "name1=" + data1+ "name2=" + 

data2;
    // 跳轉(zhuǎn)到另一個(gè)域進(jìn)行數(shù)據(jù)的處理并返回json格式的數(shù)據(jù)
    request.getRequestDispatcher(url).forward(request,response);

方法四:

    利用iframe標(biāo)簽的src屬性,進(jìn)行跨域的訪問(wèn),將獲取到的值存儲(chǔ)到當(dāng)前的iframe中,然后再

同一頁(yè)面進(jìn)行獲取該iframe的body內(nèi)的值。

  <body>
    <div id="show"></div>
    <iframe id="frame" style="display: none;"></iframe>
  </body>
  <script>
$("#frame").attr("src", "路徑?time=" + new Date().getTime()).load(function(){
  // 獲取iframe標(biāo)簽的值并進(jìn)行獲取,顯示到頁(yè)面
  $("#show").append("[data: " + $($("#frame").get(0).contentDocument).find("body").text() 

+ " ]");
});
  </script>

方法五:

    HTML5中websocket可以進(jìn)行跨域的訪問(wèn);
  創(chuàng)建一個(gè)websocket對(duì)象:

    var ws = new WebSocket(url);

  主要處理的事件類(lèi)型有(onopen,onclose,onmessage,onerror);

    例如:

    ws.onopen = function(){

      console.log("open");

      // 向后臺(tái)發(fā)送數(shù)據(jù)

      ws.send("open");

    }

    后臺(tái)可以是java,php,nodejs等,對(duì)數(shù)據(jù)處理用時(shí)間onmessage事件對(duì)返回的值進(jìn)行前端處理。

    ws.onmessage = function(eve){

      console.log(eve.data);

    }

相關(guān)文章

最新評(píng)論