国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js實現跨域的方法實例詳解

2019-11-20 12:10:59
字體:
來源:轉載
供稿:網友

本文實例講述了js實現跨域的方法。分享給大家供大家參考。具體分析如下:

由于同源策略的限制,XMLHttpRequest只允許請求當前源(包含域名、協議、端口)的資源。

json與jsonp的區別:

JSON是一種數據交換格式,而JSONP是一種依靠開發人員創造出的一種非官方跨域數據交互協議。

script標簽經常被用來加載不同域下的資源,可以繞過同源策略。(有src屬性的都可以獲取異域文件)。
如果請求的這個遠程數據本身就是一段可執行的js,那么這些js會被執行(相當于eval)。
 
方法一:

利用script標簽請求(<script src="http://....jsp?callback=回調函數名"></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);}

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广德县| 信阳市| 德格县| 抚宁县| 仲巴县| 富川| 琼结县| 巴林左旗| 大埔县| 广饶县| 绥芬河市| 都兰县| 栾川县| 新巴尔虎右旗| 盐源县| 成安县| 斗六市| 石河子市| 辛集市| 遂溪县| 五指山市| 华池县| 布拖县| 吉安县| 浑源县| 定襄县| 新津县| 瓮安县| 万山特区| 攀枝花市| 新竹县| 泸西县| 新龙县| 平谷区| 内黄县| 安泽县| 石城县| 曲阳县| 祁阳县| 廊坊市| 绥芬河市|