javascript實(shí)現(xiàn)跨域的方法匯總
由于同源策略的限制,XMLHttpRequest只允許請求當(dāng)前源(包含域名、協(xié)議、端口)的資源。
json與jsonp的區(qū)別:
JSON是一種數(shù)據(jù)交換格式,而JSONP是一種依靠開發(fā)人員創(chuàng)造出的一種非官方跨域數(shù)據(jù)交互協(xié)議。
script標(biāo)簽經(jīng)常被用來加載不同域下的資源,可以繞過同源策略。(有src屬性的都可以獲取異域文件)。
如果請求的這個遠(yuǎn)程數(shù)據(jù)本身就是一段可執(zhí)行的js,那么這些js會被執(zhí)行(相當(dāng)于eval)。
方法一:
利用script標(biāo)簽請求(<script src="http://....jsp?callback=回調(diào)函數(shù)名"></script>)
在使用script標(biāo)簽請求前,先進(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來傳遞javascript對象是一種最簡單的方式了,這樣的跨域通訊方式稱為JSONP。
遠(yuǎn)程服務(wù)器拼湊字符串:
回調(diào)函數(shù)名( {"name1":"data1","name2","data2"} )
這種以后臺拼湊json數(shù)據(jù),利用回調(diào)函數(shù)傳參的形式返回給客戶端
(可以直接調(diào)用相當(dāng)于已經(jīng)將獲取的字符串進(jìn)行eval了處理)
例如:function databack(data){ alert(data.name1) } // 會輸出顯示"data1"
方法二:
jquery實(shí)現(xiàn)異域加載方法更為簡單(與ajax異步請求方式相同)
$.ajax({
type : "get",
dataType:"json",
success : function(data){ alert(data.name1) };
})
或者簡寫形式
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ù)端代理
在同源的后臺設(shè)置一個代理程序(proxy.jsp...);在服務(wù)器端與異域的服務(wù)器交互。
jquery前臺傳輸數(shù)據(jù):
例如:
$.get(
'http://。。。.jsp', // 代理程序地址
{
name1 : "data1",
name2 : "data2"
},
function(data){
if(data == 1) alert('發(fā)送成功!');
}
);
后臺數(shù)據(jù)的處理 :
String data1 = request.getParameter("name1");
........
// 此處的url為另一域下的地址并帶有參數(shù)
String url = "http://.....com/.../sss.jsp?" + "name1=" + data1+ "name2=" +
data2;
// 跳轉(zhuǎn)到另一個域進(jìn)行數(shù)據(jù)的處理并返回json格式的數(shù)據(jù)
request.getRequestDispatcher(url).forward(request,response);
方法四:
利用iframe標(biāo)簽的src屬性,進(jìn)行跨域的訪問,將獲取到的值存儲到當(dāng)前的iframe中,然后再
同一頁面進(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)行獲取,顯示到頁面
$("#show").append("[data: " + $($("#frame").get(0).contentDocument).find("body").text()
+ " ]");
});
</script>
方法五:
HTML5中websocket可以進(jìn)行跨域的訪問;
創(chuàng)建一個websocket對象:
var ws = new WebSocket(url);
主要處理的事件類型有(onopen,onclose,onmessage,onerror);
例如:
ws.onopen = function(){
console.log("open");
// 向后臺發(fā)送數(shù)據(jù)
ws.send("open");
}
后臺可以是java,php,nodejs等,對數(shù)據(jù)處理用時間onmessage事件對返回的值進(jìn)行前端處理。
ws.onmessage = function(eve){
console.log(eve.data);
}
相關(guān)文章
原生js實(shí)現(xiàn)trigger方法示例代碼
這篇文章主要給大家介紹了關(guān)于利用原生js實(shí)現(xiàn)trigger方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
JS中BOM相關(guān)知識點(diǎn)總結(jié)(必看篇)
下面小編就為大家?guī)硪黄狫S中BOM相關(guān)知識點(diǎn)總結(jié)(必看篇)。小編覺得挺不錯的,希望對大家有所幫助。一起跟隨小編過來看看吧,祝大家游戲愉快哦2016-11-11
iframe父子頁面實(shí)現(xiàn)共用滾動條的常見方法
在開發(fā)過程中,有時候需要用到iframe復(fù)用不同域名下的頁面內(nèi)容,為了提供連貫的用戶體驗(yàn),經(jīng)常需要在主頁面(父頁面)和iframe子頁面之間共享滾動位置,本文將介紹其中較為常見的一種方法來實(shí)現(xiàn)iframe父子頁面共用滾動條,需要的朋友可以參考下2024-05-05
基于JavaScript實(shí)現(xiàn)熔巖燈效果導(dǎo)航菜單
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)熔巖燈效果導(dǎo)航菜單,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
基于JavaScript+HTML5 實(shí)現(xiàn)打地鼠小游戲邏輯流程圖文詳解(附完整代碼)
打地鼠小游戲大家都喜歡玩,本文是以html編寫的,并且使用HBulider軟件進(jìn)行編寫的,下面通過本文給大家分享基于JavaScript+HTML5 實(shí)現(xiàn)打地鼠小游戲邏輯流程圖文詳解,需要的朋友參考下吧2017-11-11
深入理解JavaScript系列(16) 閉包(Closures)
本章我們將介紹在JavaScript里大家經(jīng)常來討論的話題 —— 閉包(closure)。閉包其實(shí)大家都已經(jīng)談爛了。盡管如此,這里還是要試著從理論角度來討論下閉包,看看ECMAScript中的閉包內(nèi)部究竟是如何工作的2012-04-04
當(dāng)前流行的JavaScript代碼風(fēng)格指南
這篇文章主要介紹了當(dāng)前流行的JavaScript代碼風(fēng)格指南,同時推薦了一款風(fēng)格檢驗(yàn)工具jshint,可以配合大多數(shù)的編輯器統(tǒng)一團(tuán)隊(duì)代碼風(fēng)格,需要的朋友可以參考下2014-09-09
JS實(shí)現(xiàn)多張圖片預(yù)覽同步上傳功能
這篇文章主要介紹了JS實(shí)現(xiàn)多張圖片預(yù)覽同步上傳功能的相關(guān)資料,需要的朋友可以參考下2017-06-06

