javascript實作跨域的方法總結_javascript技巧
由於同源策略的限制,XMLHttpRequest只允許請求目前來源(包含網域名稱、協定、連接埠)的資源。
json與jsonp的差別:
JSON是一種資料交換格式,而JSONP是一種依賴開發人員創造出的一種非官方跨域資料互動協定。
script標籤經常被用來載入不同網域下的資源,可以繞過同源策略。 (有src屬性的都可以取得異域檔案)。
如果要求的這個遠端資料本身就是一段可執行的js,那麼這些js就會被執行(相當於eval)。
方法一:
利用script標籤請求()
在使用script標籤請求前,先進行回呼函數的申明調用,
<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非同步請求方式相同)
$.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前台傳輸資料:
例如:
$.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?" + "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", "路径?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); }

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript中的HTTP狀態碼取得方法簡介:在進行前端開發中,我們常常需要處理與後端介面的交互,而HTTP狀態碼就是其中非常重要的一部分。了解並取得HTTP狀態碼有助於我們更好地處理介面傳回的資料。本文將介紹使用JavaScript取得HTTP狀態碼的方法,並提供具體程式碼範例。一、什麼是HTTP狀態碼HTTP狀態碼是指當瀏覽器向伺服器發起請求時,服務
