javascript實現跨域的方法匯總

來源:互聯網
上載者:User

javascript實現跨域的方法匯總

   這篇文章主要給大家匯總介紹了javascript實現跨域的方法的相關資料,需要的朋友可以參考下

  由於同源策略的限制,XMLHttpRequest只允許請求當前源(包含網域名稱、協議、連接埠)的資源。

  json與jsonp的區別:

  JSON是一種資料交換格式,而JSONP是一種依靠開發人員創造出的一種非官方跨域資料互動協議。

  script標籤經常被用來載入不同域下的資源,可以繞過同源策略。(有src屬性的都可以擷取異域檔案)。

  如果請求的這個遠端資料本身就是一段可執行檔js,那麼這些js會被執行(相當於eval)。

  方法一:

  利用script標籤請求( )

  在使用script標籤請求前,先進行回呼函數的申明調用,

  ?

1

2

3

4

<script>

function 回呼函數名(data資料){ 。。。。 }

</script>

<script src="http://....jsp?callback=回呼函數名"></script>

  使用JSON來傳遞javascript對象是一種最簡單的方式了,這樣的跨域通訊方式稱為JSONP。

  遠程伺服器拼湊字串:

  回呼函數名( {"name1":"data1","name2","data2"} )

  這種以後台拼湊json資料,利用回呼函數傳參的形式返回給用戶端

  (可以直接調用相當於已經將擷取的字串進行eval了處理)

  例如:function databack(data){ alert(data.name1) } // 會輸出顯示"data1"

  方法二:

  jquery實現異域載入方法更為簡單(與ajax非同步請求方式相同)

  ?

1

2

3

4

5

$.ajax({

type : "get",

dataType:"json",

success : function(data){ alert(data.name1) };

})

  或者簡寫形式

  var url = "http://.....jsp?callback=?"; // 在jquery中此處的callback值可以為任意,因為

  jquery進行處理後都是利用success回呼函數進行資料的接受;

  $.getJSON( url, function(data){ alert(data.name1) });

  方法三:

  ajax跨域之服務端代理

  在同源的後台設定一個代理程式(proxy.jsp...);在伺服器端與異域的伺服器互動。

  jquery前台傳輸資料:

  例如:

  ?

1

2

3

4

5

6

7

8

9

10

  $.get(

   'http://。。。.jsp', // 代理程式地址

   {

   name1 : "data1",

   name2 : "data2"

   },

   function(data){

   if(data == 1) alert('發送成功!');

   }

   );

  後台資料的處理 :

  ?

1

2

3

4

5

6

7

8

String data1 = request.getParameter("name1");

........

// 此處的url為另一域下的地址並帶有參數

String url = "http://.....com/.../sss.jsp?" + "name1=" + data1+ "name2=" +

 

data2;

// 跳轉到另一個域進行資料的處理並返回json格式的資料

request.getRequestDispatcher(url).forward(request,response);

  方法四:

  利用iframe標籤的src屬性,進行跨域的訪問,將擷取到的值儲存到當前的iframe中,然後再

  同一頁面進行擷取該iframe的body內的值。

  ?

1

2

3

4

5

6

7

8

9

10

11

12

<body>

<div id="show"></div>

<iframe id="frame" style="display: none;"></iframe>

</body>

<script>

$("#frame").attr("src", "路徑?time=" + new Date().getTime()).load(function(){

// 擷取iframe標籤的值並進行擷取,顯示到頁面

$("#show").append("[data: " + $($("#frame").get(0).contentDocument).find("body").text()

 

+ " ]");

});

</script>

  方法五:

  HTML5中websocket可以進行跨域的訪問;

  建立一個websocket對象:

  var ws = new WebSocket(url);

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

  例如:

  ?

1

2

3

4

5

6

7

8

9

    ws.onopen = function(){

 

      console.log("open");

 

      // 向後台發送資料

 

      ws.send("open");

 

    }

  後台可以是java,php,nodejs等,對資料處理用時間onmessage事件對返回的值進行前端處理。

  ?

1

2

3

4

5

    ws.onmessage = function(eve){

 

      console.log(eve.data);

 

    }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.