js實(shí)現(xiàn)跨域的方法實(shí)例詳解
本文實(shí)例講述了js實(shí)現(xiàn)跨域的方法。分享給大家供大家參考。具體分析如下:
由于同源策略的限制,XMLHttpRequest只允許請(qǐng)求當(dāng)前源(包含域名、協(xié)議、端口)的資源。
json與jsonp的區(qū)別:
JSON是一種數(shù)據(jù)交換格式,而JSONP是一種依靠開(kāi)發(fā)人員創(chuàng)造出的一種非官方跨域數(shù)據(jù)交互協(xié)議。
script標(biāo)簽經(jīng)常被用來(lái)加載不同域下的資源,可以繞過(guò)同源策略。(有src屬性的都可以獲取異域文件)。
如果請(qǐng)求的這個(gè)遠(yuǎn)程數(shù)據(jù)本身就是一段可執(zhí)行的js,那么這些js會(huì)被執(zhí)行(相當(dāng)于eval)。
方法一:
利用script標(biāo)簽請(qǐng)求(<script src="http://....jsp?callback=回調(diào)函數(shù)名"></script>)
在使用script標(biāo)簽請(qǐng)求前,先進(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來(lái)傳遞javascript對(duì)象是一種最簡(jiǎn)單的方式了,這樣的跨域通訊方式稱(chēng)為JSONP。
遠(yuǎn)程服務(wù)器拼湊字符串:
回調(diào)函數(shù)名( {"name1":"data1","name2","data2"} )
這種以后臺(tái)拼湊json數(shù)據(jù),利用回調(diào)函數(shù)傳參的形式返回給客戶(hù)端
(可以直接調(diào)用相當(dāng)于已經(jīng)將獲取的字符串進(jìn)行eval了處理)
例如:
function databack(data){ alert(data.name1) } // 會(huì)輸出顯示"data1"
方法二:
jquery實(shí)現(xiàn)異域加載方法更為簡(jiǎn)單(與ajax異步請(qǐng)求方式相同)
$.ajax({ type : "get", dataType:"json", success : function(data){ alert(data.name1) }; })
或者簡(jiǎn)寫(xiě)形式
var url = "http://.....jsp?callback=?"; // 在jquery中此處的callback值可以為任意, // 因?yàn)閖query進(jìn)行處理后都是利用success回調(diào)函數(shù)進(jìn)行數(shù)據(jù)的接受; $.getJSON( url, function(data){ alert(data.name1) });
方法三:
ajax跨域之服務(wù)端代理
在同源的后臺(tái)設(shè)置一個(gè)代理程序(proxy.jsp...);
在服務(wù)器端與異域的服務(wù)器交互。
jquery前臺(tái)傳輸數(shù)據(jù):
例如:
$.get( 'http://。。。.jsp', // 代理程序地址 { name1 : "data1", name2 : "data2" }, function(data){ if(data == 1) alert('發(fā)送成功!'); } );
后臺(tái)數(shù)據(jù)的處理 :
String data1 = request.getParameter("name1"); ........ // 此處的url為另一域下的地址并帶有參數(shù) String url = "http://.....com/.../sss.jsp?" + "name1=" + data1+ "name2=" + data2; // 跳轉(zhuǎn)到另一個(gè)域進(jìn)行數(shù)據(jù)的處理并返回json格式的數(shù)據(jù) request.getRequestDispatcher(url).forward(request,response);
方法四:
利用iframe標(biāo)簽的src屬性,進(jìn)行跨域的訪(fǎng)問(wèn),將獲取到的值存儲(chǔ)到當(dāng)前的iframe中,然后再同一頁(yè)面進(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)行獲取,顯示到頁(yè)面 $("#show").append("[data: " + $($("#frame").get(0).contentDocument).find("body").text()+ " ]"); }); </script>
方法五:
HTML5中websocket可以進(jìn)行跨域的訪(fǎng)問(wèn);
創(chuàng)建一個(gè)websocket對(duì)象:
主要處理的事件類(lèi)型有(onopen,onclose,onmessage,onerror);
例如:
ws.onopen = function(){ console.log("open"); // 向后臺(tái)發(fā)送數(shù)據(jù) ws.send("open"); }
后臺(tái)可以是java,php,nodejs等,對(duì)數(shù)據(jù)處理用時(shí)間onmessage事件對(duì)返回的值進(jìn)行前端處理。
ws.onmessage = function(eve){ console.log(eve.data); }
希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。
相關(guān)文章
將html頁(yè)面保存成圖片,圖片寫(xiě)入pdf的實(shí)現(xiàn)方法(推薦)
下面小編就為大家?guī)?lái)一篇將html頁(yè)面保存成圖片,圖片寫(xiě)入pdf的實(shí)現(xiàn)方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09JS使用 cryptojs加密解密(對(duì)稱(chēng)加密庫(kù))的問(wèn)題
js 加密解密可以使用 crypto-js,這是一個(gè)對(duì)稱(chēng)加密的庫(kù), 可以使用 AES DES 但沒(méi)有 rsa 等非對(duì)稱(chēng)加密的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2023-11-11Webpack中使用環(huán)境變量的各種正確姿勢(shì)
我們?cè)陂_(kāi)發(fā)項(xiàng)目中都會(huì)遇到這種場(chǎng)景,區(qū)分開(kāi)發(fā)環(huán)境、生產(chǎn)環(huán)境、測(cè)試環(huán)境,不同場(chǎng)景請(qǐng)求不同的接口Api,這時(shí)候項(xiàng)目中配置的「環(huán)境變量」就登場(chǎng)啦,這篇文章主要給大家介紹了關(guān)于Webpack中使用環(huán)境變量的各種正確姿勢(shì),需要的朋友可以參考下2021-09-09JavaScript數(shù)據(jù)結(jié)構(gòu)yocto queue隊(duì)列鏈表代碼分析
這篇文章主要為大家介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)yocto queue隊(duì)列鏈表代碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12JavaScript中offsetWidth的bug及解決方法
這篇文章主要為大家詳細(xì)介紹了JavaScript中offsetWidth的bug及解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05JavaScript實(shí)現(xiàn)簡(jiǎn)單獲取當(dāng)前網(wǎng)頁(yè)網(wǎng)址的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單獲取當(dāng)前網(wǎng)頁(yè)網(wǎng)址的方法,通過(guò)location對(duì)象的href方法來(lái)獲取網(wǎng)址,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-11-11JavaScript逆向調(diào)試技巧總結(jié)分享
當(dāng)我們抓取網(wǎng)頁(yè)端數(shù)據(jù)時(shí),經(jīng)常被加密參數(shù)、加密數(shù)據(jù)所困擾,如何快速定位這些加解密函數(shù),尤為重要,下面這篇文章主要給大家介紹了關(guān)于JavaScript逆向調(diào)試技巧的相關(guān)資料,需要的朋友可以參考下2022-06-06JavaScript實(shí)現(xiàn)JSON合并操作示例【遞歸深度合并】
這篇文章主要介紹了JavaScript實(shí)現(xiàn)JSON合并操作,結(jié)合實(shí)例形式分析了javascript基于遞歸深度實(shí)現(xiàn)json合并操作相關(guān)實(shí)現(xiàn)技巧與注意事項(xiàng),需要的朋友可以參考下2018-09-09