公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

Javascript 跨域訪問解決方案

admin
2013年9月3日 14:41 本文熱度 4839
由于安全方面的考慮,Javascript被限制了跨域訪問的能力,但是有時(shí)候我們希望能夠做一些合理的跨域訪問的事情,那么怎么辦呢?

 

這里分兩類情況:
一、基于同一父域的子域之間頁面的訪問;參見如下3個(gè)domain域:taobao.com、jipiao.taobao.com、promotion.taobao.com;它們有相同的父域taobao.com。
二、基于不同父域頁面之間的訪問;參見如下3個(gè)domain域:taobao.com、baidu.com、sina.com.cn;它們具有不同的父域。

解決它們之間跨域的方案有:
方案1:服務(wù)器Proxy
域A的頁面JS需要訪問域B下的鏈接獲取數(shù)據(jù),該方案在域A的服務(wù)器端建立一個(gè)Proxy程序(可能是ASP、servlet等任何服務(wù)端程序),域A的頁面JS直接調(diào)用本域下的Proxy程序,proxy程序負(fù)責(zé)將請(qǐng)求發(fā)送給域B下的鏈接并獲取到數(shù)據(jù),最后再通過Proxy將數(shù)據(jù)返回給頁面JS使用。
經(jīng)過的訪問流程就是: 域A下JS --> 域A 下Proxy -- > 域B下的鏈接
例子:
第一步:
域A: http://Jipiao.taobao.com/test.htm
頁面上javascript腳本:


代碼如下:


<script type="text/javascript"><!--
Var sUrl="http://Jipiao.taobao.com/proxy.do"; //本域下代理地址
var callback =
{
success: function(res) { alert(res.responseText); },
failure: function(res) { alert('failure');},
argument:{}
}
YAHOO.util.Connect.asyncRequest('GET', sUrl, callback, null);
// --></script>

第二步:
完成域A服務(wù)端的Proxy程序(這里假定是一個(gè)servlet),偽碼如下:

代碼如下:


Public class Proxy extends …….{
..doGet(……..){
HttpClient client=……;
GetMethod get=new GetMethod("www.baidu.com/xxxxx.do");//訪問域B的鏈接
int statusCode = client.executeMethod(get);
if (statusCode != HttpStatus.SC_OK) {
byte[] responseBody = get.getResponseBody();
String res=new String(responseBody);
Httpresponse.getWriter().write(res);//將數(shù)據(jù)返回給域A
}
}
}

方案2:通過Script標(biāo)簽:
在域A頁面http://Jipiao.taobao.com/test.htm 的head中寫一個(gè)空的Script標(biāo)簽:

代碼如下:


<html>
<head>
<script id="remoteScript" type="text/javascript" src=""/><!--
<head>
<body>
<script type="text/javascript" >
Var remoteScript=document.getElementById("remoteScript");
remoteScript.src="www.baidu.com/xxxxx.do";//域B的鏈接
alert(remote.test);//使用域B返回的JSON數(shù)據(jù)
alert(f[0]);
// --></script>
</body>
</html>

注意:這種方案要求域B返回的數(shù)據(jù)必須是合法的JSON格式或者如JS文件的格式;比如域B返回的數(shù)據(jù)格式如下:
Var remote={test:'hello'};
Var f=[2,1];

方案3:隱藏iframe、共享domain:
即域A頁面http://jipiao.taobao.com/yyyy.htm 的頁面上寫一個(gè)隱藏的iframe:

代碼如下:
<html>
<head>
<head>
<body>
<script type="text/javascript" ><!--
Document.domain="taobao.com";
Var remoteHtml=document.getElementById("remoteHtml");
remoteHtml.src="promotion.taobao.com/xxxx.htm";//這里訪問域B的鏈接
var document=remoteHtml.ContentDocument; //這里就可以使用document來操作域B中頁面xxx.htm的數(shù)據(jù)了
// --></script>
<iframe id="remoteHtml" src="" style="diapay:none" style="diapay:none"/>
</body>
</html>

注意:這里http://promotion.taobao.com/xxxx.htm 頁面也需要設(shè)置document.domain="taobao.com", 這種方法才能奏效。
之所以這種iframe的方法不適合不同父域之間的跨域,是因?yàn)樵O(shè)置document.domain只能設(shè)置為自己的父域,而不是能設(shè)置為其他域,例如:jiapiao.taobao.com只能設(shè)置document.domain="taobao.com",而不能是document.domain="baidu.com";
這里列舉的三種方案各有優(yōu)缺點(diǎn):
Proxy方案優(yōu)點(diǎn)是可以適用用于幾乎所有的跨域訪問,而且只需要要一個(gè)域中進(jìn)行開發(fā),另一個(gè)域可以提供任何類型格式的數(shù)據(jù)。缺點(diǎn)是這種方案經(jīng)過了中間Proxy,所以延遲可能稍微大一點(diǎn),并且會(huì)加重本域服務(wù)器的負(fù)荷,開發(fā)工作量也稍微大一點(diǎn)。
Script標(biāo)簽的方案可以說是非常簡(jiǎn)單的,不用幾行代碼就搞定了事,不過它對(duì)返回的數(shù)據(jù)格式要求有點(diǎn)嚴(yán)格,只能是Json格式數(shù)據(jù),如果是其他格式的數(shù)據(jù),那么這種方法就無能為力了。
隱藏iframe方式也很簡(jiǎn)單,它可以處理任何返回的數(shù)據(jù)格式,但它只適用在具有同一個(gè)父域下的跨域請(qǐng)求上,并且要求其他域得配合開發(fā),即需要設(shè)置document.domain。
原帖詳見:http://blog.csdn.net/lovingprince/archive/2008/09/20/2954675.aspx

--------------------------------------------------------------------------------
對(duì)于JS跨域訪問的意思,我想再補(bǔ)充幾點(diǎn):
跨域訪問,簡(jiǎn)單來說就是 A 網(wǎng)站的 javascript 代碼試圖訪問 B 網(wǎng)站,包括提交內(nèi)容和獲取內(nèi)容;比如想從A網(wǎng)站的頁面中執(zhí)行另外一個(gè)B網(wǎng)站內(nèi)某頁面中的JS對(duì)象、或者想在A網(wǎng)站的頁面中用JS去解析B網(wǎng)站內(nèi)某頁面的dom元素等;出現(xiàn)這種跨域訪問問題的應(yīng)用場(chǎng)景一般是iframe中嵌入不同域的頁面、或者向不同域發(fā)送Ajax請(qǐng)求等;
由于安全原因,跨域訪問是被各大瀏覽器所默認(rèn)禁止的;但是瀏覽器并不禁止在頁面中引用其他域的JS文件,并可以自由執(zhí)行引入的JS文件中的function;這點(diǎn)個(gè)人覺得至關(guān)重要!
是否跨域的判斷規(guī)則為對(duì)三者進(jìn)行比較:域名、協(xié)議、端口;三者中若有一個(gè)不相同,則會(huì)出現(xiàn)跨域問題;我們經(jīng)常說的跨域問題一般指域名不同,因?yàn)檫@種場(chǎng)景出現(xiàn)的幾率最高而且有一些辦法可以解決;比如前面提到的taobao.com域下的二級(jí)域名跨域問題;
對(duì)于主域都不一樣、或者協(xié)議不同(比如https與http)的跨域問題(比如*.taobao.com域想訪問*.baidu.com域內(nèi)的內(nèi)容),想從Web端來解決是完全不可能的,只能通過服務(wù)端Proxy的方案來解決;
常見的不同域間的頁面制約dom元素包括:
window.location 可以設(shè)置,但不能讀取。其它的 location 屬性和方法被禁止訪問;
document.href 可以設(shè)置,但不能讀取。其它的 document 屬性和方法被禁止訪問;
<iframe> 的 src 可以設(shè)置,但不能讀取。

該文章在 2013/9/3 14:41:39 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 丰满女邻居的嫩苞张开视频 | 国产二区视频在线观看 | 国产在线观看一区二区三区 | 岛国一区二区三区在线观看 | 成人欧美精品视频在线观看 | 国产中文字幕乱人伦在线观看 | 国产专区一区 | 国产麻豆叶一涵剧情在线观 | 成人精品动漫一区二区三区 | 国产在线精品成人一区二区 | 国产在线观看一区免费精品 | 国产97人妻人人做人碰人人爽 | 国自产拍视频在线无码 | 高潮在线观看 | 国产欧美精品一区二区三区 | 国产精品偷伦免费视频 | 国产办公室无码视频在线观看 | 成人黄视频在线 | 国产一区二区三区av水蜜桃 | 成人综合亚洲 | 国产精品一区二区在线观看欲臀 | 国产极品精品无码在线播出 | 精品人妻系列无码专区 | 国产成人啪精品免费观看 | 国内外精品激情刺激在线 | 国产一线大片免费观看 | 精品视频在线视频观看 | 国产高清国际精品福利色噜噜 | 国模精品一区二区三区视频 | 国产成人无码a区在线观9 | 国产成人午夜福利电影在线播放 | 国产精品va在线观看无码电影 | 国产高清黄色视频 | 国产精品一级二级三级爱 | 国产成人禁片在线观看 | 国产99久久影院电影 | 国产高清毛片 | 国产高清无码不卡二区三区 | 国产精品日韩欧美久久综合 | 国产精品不卡无码av在线播 | 91精品国产免费久久国语蜜臀 |