亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

AJAX javascript的跨域訪問執行

2024-09-01 08:31:19
字體:
來源:轉載
供稿:網友
在網站調用加載評論等信息的時候遇到了不同域名間javascript不能執行的問題,一直都在加載中顯示不出來,而換個網址訪問的話就能正確顯示,一直沒去注意瀏覽器提示的錯誤信息:


突然感覺就是這里的問題,研究一下,搞定后其實覺得挺容易的,只是自己知識還是有些欠缺,解決方法如下:

阻塞的AJAX請求

  我們先來證實一下請求的阻塞情況吧。我們使用如下的代碼:

連續發起三個請求

復制代碼 代碼如下:


function simpleRequest()
{
var request = new XMLHttpRequest();
request.open(”POST“, “Script.ashx“);
request.send(null);
}
function threeRequests()
{
simpleRequest();
simpleRequest();
simpleRequest();
}


  當執行threeRequests時就會連續發出3個相同域名的請求,還是通過統計圖表來查看阻塞的效果:

AJAX javascript的跨域訪問執行
  每個請求需要花費1.5秒的時間。很明顯,第三個請求必須等到第一個請求結束之后才能執行,因此總共需要進行3秒多鐘才能執行完畢。我們要改變的就是這個狀況。

傳統的跨域名異步請求解決方案
  AJAX安全性的唯一保證,似乎就是對于跨域名(Cross-Domain)AJAX請求 的限制。除非打開本地硬盤的網頁,或者在IE中將跨域名傳輸數據的限制打開,否則向其他域名發出AJAX請求都會被禁止。而且對于跨域名的判斷非常嚴格, 不同的子域名,或者相同域名的不同端口,都會被認作是不同的域名,我們不能向它們的資源發出AJAX請求。

  從表面上看起來似乎沒有辦法打破這個限制,還好我們有個救星,那就是iframe!

  iframe雖然不在標準中出現,但是由于它實在有用,FireFox也“不得不”對它進 行了支持(類似的還有innerHTML)。網上已經有一些跨域名發出異步請求的做法,但是它們實在做的不好。它們的簡單工作原理如下:在另一個域名下放 置一個特定的頁面文件作為Proxy,主頁面將異步請求的信息通過Query String傳遞入iframe里的Proxy頁面,Proxy頁面在AJAX請求執行完畢后將結果放在自己location的hash中,而主頁面會對 iframe的src的hash值進行輪詢,一旦發現它出現了改變,則通過hash值得到需要的信息。

  這個方法的實現比較復雜,而且功能有限。在 IE和FireFox中,對于URL的長度大約可以支持2000個左右的字符。對于普通的需求它可能已經足夠了,可惜如果真要傳遞大量的數據,這就遠遠不 夠了。與我們一會兒要提出的解決方案相比,可能它唯一的優勢就是能夠跨任意域名進行異步請求,而我們的解決方案只能突破子域名的限制。

  那么現在來看看我們的做法!



優雅地突破子域名的限制

  我們突破子域名限制的關鍵還是在于iframe。

  iframe是的好東西,我們能夠跨過子域名來訪問iframe里的頁面對象,例如 window和DOM結構,包括調用JavaScript(通過window對象)——我們將內外頁面的 document.domain設為相同就可以了。然后在不同子域名的頁面發起不同的請求,把結果通過JavaScript進行傳遞即可。唯一需要的也僅 僅是一個簡單的靜態頁面作為Proxy而已。

  我們現在就來開始編寫一個原形,雖然簡單,但是可以說明問題。

  首先,我們先來編寫一個靜態頁面,作為放在iframe里的Proxy,如下:

SubDomainProxy.html

復制代碼 代碼如下:


<html xmlns=“” >
<head>
<title>Untitled Page</title>
<script type=“text/javascript” language=“javascript”>
document.domain = “test.com“;function sendRequest(method, url)
{
var request = new XMLHttpRequest();
request.open(method, url);
request.send(null);
}
</script>
</head>
<body>
</body>
</html>





  然后我們再編寫我們的主頁面:




復制代碼 代碼如下:


<html xmlns=“” >
<head runat=“server”>
<title>Untitled Page</title>
<script type=“text/javascript” language=“javascript”>
document.domain = “test.com“;function simpleRequest()
{
var request = new XMLHttpRequest();
request.open(”POST“, “Script.ashx“);
request.send(null);
}
function crossSubDomainRequest()
{
var proxy = document.getElementById(”iframeProxy“).contentWindow;
proxy.sendRequest('POST', ‘‘);
}
function threeRequests()
{
simpleRequest();
simpleRequest();
crossSubDomainRequest();
}
</script>
</head>
<body>
<input type=“button” value=“Request” onclick=“threeRequests()” />
<iframe src=http://www.aspku.com“”%20style=“display:none;”%20%20
id=“iframeProxy”></iframe>%20%20
</body>%20%20
</html>%20

%20  當執行threeRequests方法時,將會同時請求以及兩個不同域名下的資源。很明顯,最后一個請求已經不會受到前兩個請求的阻塞了:


不同域名的請求不會被阻塞

  令人滿意的結果!

  雖說只能突破子域名,但是這已經足夠了,不是嗎?我們為什么要強求任意域名之間能夠異步通 訊呢?更何況我們的解決方案是多么的優雅!在下一篇文章中,我們將會為ASP.NET AJAX客戶端實現一個完整的CrossSubDomainRequestExecutor,它會自動判斷是否正在發出跨子域名的請求,并選擇AJAX請 求的方式。這樣,客戶端的異步通訊層就會對開發人員完全透明。世上還會有比這更令人愉快的事情嗎?:)

注意事項

  可能以下幾點值得一提:

我在出現這個想法之后也作了一些嘗試,最后發現創建XMLHttpRequest對象,調用open方法和send方法都必須在iframe中的頁面中執行才能夠在IE和FireFox中成功發送AJAX請求。

在上面的例子中,我們向子域名請求的的路徑是。請注意,完整的子域名不可以省略,否則在FireFox下就會出現權限不夠的錯誤,在調用open方法時就會拋出異?!坪鮂ireFox把它當作了父頁面域名的資源了。
因為瀏覽器的安全策略,瀏覽器不允許不同域(比如:phinest.org和lab.phinest.org)、不同協議(比如: 和https://phinest.org)、不同端口(比如:http: phinest.org和:8080)下的頁面通過XMLHTTPRequest相互訪問,這個問題同樣影響著不同頁面的Javascript的相互調用和控制,但是當主域、協議、端口相同時,通過設置頁面的document.domain主域, Javascript可以在不同的子域名間訪問控制,比如通過設置document.domain='phinest.org',http: //phinest.org和頁面可互訪,這個特性也提供了此情況下不同子域名下的 XMLHTTPRequest相互訪問的解決方案。

對于主域、協議、端口相同時的Ajax跨域問題,很早就有設置document.domain來解決的說法,但一直沒有看到具體的成功應用,這次嘗試了一下,其原理就是,利用一個隱藏的iframe引入所跨另一子域的頁面作為代理,通過Javascript來控制iframe引入的另一子域的 XMLHTTPRequest來進行數據獲取。對于不同主域/不同協議/不同端口下的Ajax訪問需要通過后臺的代理來實現。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩成人免费| 亚洲成人动漫在线播放| 97在线观看免费| 欧美成人高清视频| 欧美一区二粉嫩精品国产一线天| 亚洲人成在线观看| 日韩免费视频在线观看| 欧美激情在线狂野欧美精品| 久久久久久久国产精品视频| xvideos亚洲| 成人在线免费观看视视频| 久久亚洲影音av资源网| 国产亚洲欧美另类中文| 国产脚交av在线一区二区| 中文字幕亚洲综合久久| 久久视频国产精品免费视频在线| 亚洲欧美日韩一区在线| 中文字幕久精品免费视频| 中文字幕精品一区久久久久| 亚洲乱码一区av黑人高潮| 日韩高清欧美高清| 日韩成人性视频| 在线观看免费高清视频97| 国产视频精品在线| 亚洲国产91精品在线观看| 在线播放日韩欧美| 亚洲综合中文字幕在线| 欧美日韩一区二区三区| 欧美视频中文在线看| 成人97在线观看视频| 91av在线播放| 欧美日韩在线一区| 国产精品免费网站| 久久99热这里只有精品国产| 欧美性xxxxx极品| 中文字幕日韩精品在线观看| 日韩暖暖在线视频| 国内精品久久久久久久| 亚洲最新在线视频| 欧美xxxx做受欧美| 色阁综合伊人av| 亚洲bt欧美bt日本bt| 欧美日韩国产丝袜另类| 亚洲自拍偷拍福利| 欧美日韩中文在线观看| 亚洲人精选亚洲人成在线| 91久久久久久| 国产精品aaa| 日韩成人在线免费观看| 欧美xxxx综合视频| 亚洲精品视频免费在线观看| 亚洲xxxx做受欧美| 国产69精品久久久久9| 国产在线999| 国产成人高潮免费观看精品| 国产精品影片在线观看| 懂色av一区二区三区| 久久网福利资源网站| 亚洲一区二区久久久久久| 国产成人97精品免费看片| 热久久免费视频精品| 久久国产精品首页| 亚洲国产古装精品网站| 久久久女女女女999久久| 国产精品久久久久久久久久| 91成人国产在线观看| 亚洲最大的免费| 久久久精品在线| 美女视频黄免费的亚洲男人天堂| 亚洲精品一区二区网址| 久久精品视频免费播放| 亚洲视频在线观看| 欧美有码在线观看视频| 日韩视频免费观看| 久久久久久香蕉网| 欧美日本在线视频中文字字幕| 亚洲精品自拍第一页| 成人夜晚看av| 亚洲成人国产精品| 国产精品第8页| 精品视频在线观看日韩| 成人乱人伦精品视频在线观看| 国产一区二区三区在线观看网站| 国产视频999| 色av中文字幕一区| 日韩欧美在线国产| 国产精品成人一区二区三区吃奶| 操91在线视频| 成人免费视频xnxx.com| 性欧美xxxx交| 性欧美长视频免费观看不卡| 日韩中文字幕在线免费观看| 欧美日韩裸体免费视频| 日本高清不卡在线| 91精品国产亚洲| 国产精品www网站| 欧美精品18videos性欧美| 欧美日韩亚洲高清| 欧美日韩中文字幕综合视频| 精品人伦一区二区三区蜜桃网站| 亚洲激情视频在线| 亚洲欧美在线一区| 日韩av免费在线观看| 欧美午夜精品伦理| 欧美精品videossex88| 久久91精品国产91久久跳| 亚洲国产精品资源| 国产va免费精品高清在线观看| 日韩一区视频在线| 亚洲第一天堂无码专区| 国产精品一区专区欧美日韩| 久热精品视频在线| 久久在线观看视频| 91精品国产综合久久香蕉最新版| 国产婷婷色综合av蜜臀av| 日韩av在线一区二区| 欧美性极品xxxx做受| 亚洲天堂网站在线观看视频| 日本免费久久高清视频| 午夜精品一区二区三区在线| 亚洲最大中文字幕| 亚洲xxxx做受欧美| 国产精品视频自拍| 欧美成人午夜剧场免费观看| 国产精品igao视频| 在线观看不卡av| 国产精品香蕉av| 亚洲激情在线观看视频免费| 欧美一级片久久久久久久| 国产a∨精品一区二区三区不卡| 亚洲男人的天堂在线播放| 欧美一级淫片aaaaaaa视频| 青草青草久热精品视频在线观看| 亚洲国产精久久久久久久| 秋霞成人午夜鲁丝一区二区三区| 日韩欧美成人免费视频| 亚洲аv电影天堂网| 欧美日韩中文在线| 国产精品成人播放| 成人综合国产精品| 日韩免费视频在线观看| 中文字幕久热精品在线视频| 亚洲成人亚洲激情| 亚洲香蕉成人av网站在线观看| 久久99精品国产99久久6尤物| 最近2019中文字幕大全第二页| 久久全球大尺度高清视频| 欧美国产日韩xxxxx| 亚洲精品在线不卡| 日韩在线欧美在线国产在线| 国产综合久久久久| 亚洲一区二区三区视频| 91精品国产高清久久久久久91| 国产亚洲精品综合一区91| 国产精品第3页| 欧美最猛性xxxxx(亚洲精品)| 久热在线中文字幕色999舞| 久青草国产97香蕉在线视频| 亚洲午夜未删减在线观看| 欧美在线国产精品| 亚洲人在线观看| 最近中文字幕mv在线一区二区三区四区| 亚洲影视九九影院在线观看| 久久成人精品一区二区三区|