首頁 >web前端 >js教程 >js實作跨域的方法實例詳解_javascript技巧

js實作跨域的方法實例詳解_javascript技巧

WBOY
WBOY原創
2016-05-16 15:53:231148瀏覽

本文實例講述了js實作跨域的方法。分享給大家供大家參考。具體分析如下:

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

json與jsonp的差別:

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

script標籤經常被用來載入不同網域下的資源,可以繞過同源策略。 (有src屬性的都可以取得異域檔案)。
如果要求的這個遠端資料本身就是一段可執行的js,那麼這些js就會被執行(相當於eval)。
 
方法一:

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

<script>
function 回调函数名(data数据){ 。。。。 }
</script>
<script src="http://....jsp&#63;callback=回调函数名"></script>

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

遠端伺服器拼湊字串:

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

這種以後台拼湊json數據,利用回呼函數傳參的形式回傳給客戶端
(可以直接呼叫相當於已經將取得的字串進行eval了處理)

例如:

function databack(data){ alert(data.name1) }
// 会输出显示"data1"

方法二:

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

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

或簡寫形式

var url = "http://.....jsp&#63;callback=&#63;";
// 在jquery中此处的callback值可以为任意,
// 因为jquery进行处理后都是利用success回调函数进行数据的接受;
$.getJSON( url, function(data){ alert(data.name1) });

方法三:

ajax跨域之服務端代理

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

jquery前台傳輸資料:

例如:

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

後台資料的處理 :

String data1 = request.getParameter("name1");
........
// 此处的url为另一域下的地址并带有参数
String url = "http://.....com/.../sss.jsp&#63;" + "name1=" + data1+ "name2=" + data2;
// 跳转到另一个域进行数据的处理并返回json格式的数据
request.getRequestDispatcher(url).forward(request,response);

方法四:

利用iframe標籤的src屬性,進行跨域的訪問,將取得到的值儲存到目前的iframe中,然後再同一頁面進行取得該iframe的body內的值。

<body>
  <div id="show"></div>
  <iframe id="frame" style="display: none;"></iframe>
</body>
<script>
$("#frame").attr("src", "路径&#63;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);

例如:
ws.onopen = function(){
console.log("open");
// 向后台发送数据
ws.send("open");
}

後台可以是java,php,nodejs等,對資料處理用時間onmessage事件對傳回的值進行前端處理。
ws.onmessage = function(eve){
console.log(eve.data);
}

希望本文所述對大家的javascript程式設計有所幫助。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn