這篇文章主要給大家匯總介紹了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);新聞熱點
疑難解答