天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Javascript 跨域訪問解決方案

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

解決它們之間跨域的方案有:
方案1:服務器Proxy
域A的頁面JS需要訪問域B下的鏈接獲取數據,該方案在域A的服務器端建立一個Proxy程序(可能是ASP、servlet等任何服務端程序),域A的頁面JS直接調用本域下的Proxy程序,proxy程序負責將請求發送給域B下的鏈接并獲取到數據,最后再通過Proxy將數據返回給頁面JS使用。
經過的訪問流程就是: 域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服務端的Proxy程序(這里假定是一個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);//將數據返回給域A
}
}
}

方案2:通過Script標簽:
在域A頁面http://Jipiao.taobao.com/test.htm 的head中寫一個空的Script標簽:
復制代碼 代碼如下:
<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數據
alert(f[0]);
// --></script>
</body>
</html>

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

方案3:隱藏iframe、共享domain:
即域A頁面http://jipiao.taobao.com/yyyy.htm 的頁面上寫一個隱藏的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的數據了
// --></script>
<iframe id="remoteHtml" src="" style="diapay:none" style="diapay:none"/>
</body>
</html>

注意:這里http://promotion.taobao.com/xxxx.htm 頁面也需要設置document.domain="taobao.com", 這種方法才能奏效。
之所以這種iframe的方法不適合不同父域之間的跨域,是因為設置document.domain只能設置為自己的父域,而不是能設置為其他域,例如:jiapiao.taobao.com只能設置document.domain="taobao.com",而不能是document.domain="baidu.com";
這里列舉的三種方案各有優缺點:
Proxy方案優點是可以適用用于幾乎所有的跨域訪問,而且只需要要一個域中進行開發,另一個域可以提供任何類型格式的數據。缺點是這種方案經過了中間Proxy,所以延遲可能稍微大一點,并且會加重本域服務器的負荷,開發工作量也稍微大一點。
Script標簽的方案可以說是非常簡單的,不用幾行代碼就搞定了事,不過它對返回的數據格式要求有點嚴格,只能是Json格式數據,如果是其他格式的數據,那么這種方法就無能為力了。
隱藏iframe方式也很簡單,它可以處理任何返回的數據格式,但它只適用在具有同一個父域下的跨域請求上,并且要求其他域得配合開發,即需要設置document.domain。
原帖詳見:http://blog.csdn.NET/lovingprince/archive/2008/09/20/2954675.ASPx
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
對于JS跨域訪問的意思,我想再補充幾點:
跨域訪問,簡單來說就是 A 網站的 Javascript 代碼試圖訪問 B 網站,包括提交內容和獲取內容;比如想從A網站的頁面中執行另外一個B網站內某頁面中的JS對象、或者想在A網站的頁面中用JS去解析B網站內某頁面的dom元素等;出現這種跨域訪問問題的應用場景一般是iframe中嵌入不同域的頁面、或者向不同域發送Ajax請求等;
由于安全原因,跨域訪問是被各大瀏覽器所默認禁止的;但是瀏覽器并不禁止在頁面中引用其他域的JS文件,并可以自由執行引入的JS文件中的function;這點個人覺得至關重要!
是否跨域的判斷規則為對三者進行比較:域名、協議、端口;三者中若有一個不相同,則會出現跨域問題;我們經常說的跨域問題一般指域名不同,因為這種場景出現的幾率最高而且有一些辦法可以解決;比如前面提到的taobao.com域下的二級域名跨域問題;
對于主域都不一樣、或者協議不同(比如https與http)的跨域問題(比如*.taobao.com域想訪問*.baidu.com域內的內容),想從Web端來解決是完全不可能的,只能通過服務端Proxy的方案來解決;
常見的不同域間的頁面制約dom元素包括:
window.location 可以設置,但不能讀取。其它的 location 屬性和方法被禁止訪問;
document.href 可以設置,但不能讀取。其它的 document 屬性和方法被禁止訪問;
<iframe> 的 src 可以設置,但不能讀取;

JavaScript技術Javascript 跨域訪問解決方案,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产在线AV一区二区香蕉 | 麻豆沈芯语 | 国产精品久久精品 | 亚洲AV國產国产久青草 | 欧美日韩1区 | 久久精品熟女亚洲AV国产 | 古月娜下面好紧好爽 | 日本高清片免费观看 | 99无码熟妇丰满人妻啪啪 | 激情内射亚洲一区二区三区 | 性XXXXX搡XXXXX搡景甜 | 蛇缚dvd | 暖暖高清视频免费 | 欧美hdxxxx| 伊人久久精品99热超碰 | 天天槽任我槽免费 | 亚洲AV无码久久流水呻蜜桃久色 | 蜜臀AV精品久久无码99 | 国产在线视频一区二区不卡 | 1973性农场未删减版 | 91涩涩视频 | 中文字幕在线视频网站 | 亚洲黄色片免费看 | yellow在线观看免费高清的日本 | 久久人妻少妇嫩草AV無碼 | 一个人免费视频在线观看高清频道 | 插曲的痛30分钟视频最新章节 | 雪恋电影完整版免费观看 | 成人毛片大全 | www.欧美与曽交性video | 亚洲精品国偷拍自产在线观看蜜臀 | 麻豆官网md.pub | 九九在线中文字幕无码 | 久久久久久免费观看 | YELLOW日本免费观看播放 | 精品国产中文字幕在线视频 | 在线观看免费国产成人软件 | 好男人在线视频 | 蜜臀AV色欲A片无码一区 | 日本电影免费久久精品 | 色欲久久综合亚洲精品蜜桃 |