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); } |