透過JS跨網域存取XML檔

為了一些安全性的因素,通常伺服器會阻擋跨網域的XML存取,當然如果你是該網站開發者,所開發的頁面應該將會被放在被認可的網域中,不會碰到這個問題,但我們在開發前期有可能會不在所屬的網域,這樣就會造成開發上的困難,不過我們可以透過Yahoo所提供的YQL查詢語法來解決這個問題,以下就是相關的說明:

若我們在自己的電腦用以下的語法去存取一個網路上的XML

<script>
    $(function () {
        var xmlSource = "http://stanley.cloudlab.tw/crossDomainXML/testXML.xml";
        $.ajax({
            url: xmlSource,
            success: function (data) {
                console.log(data);
            }
        })
    })
</script>

很可能會出現「No Access Control Allow Origin」的訊息:

Cross doamin XML access

但如果套用上YQL之後

<script>
$(function(){
	var xmlSource = "http://stanley.cloudlab.tw/crossDomainXML/testXML.xml";
	var yqlURL = [
		"http://query.yahooapis.com/v1/public/yql",
		"?q=" + encodeURIComponent("select * from xml where url='" + xmlSource + "'"),
		"&format=xml&callback=?"
	].join("");

	$.getJSON(yqlURL, function(data){
		console.log(data)
	});
	
})
</script>
Cross doamin XML access

可以看到已經可以抓到XML內容,這樣可以讓我們較為方便的去開發,其他詳細的使用說明可以參考Yahoo YQL Guide

You may also like...

49,589 Responses

  1. нарколог на дому капельница цена нарколог на дому капельница цена .

  2. BradleyEdino表示:

    deneme bonusu veren siteler yeni deneme bonusu veren siteler yeni deneme bonusu veren siteler

  3. Jimmylop表示:

    kraken13.at – маркетплейс кракен kraken darknet top, kraken тор

  4. In creating the historical past for The Empire Strikes Back, Lucas condensed this into one character in the type of Darth Vader.

  5. Jimmylop表示:

    kraken20 at com – http kraken20 at официальный сайт, кракен магазин

  6. Wallacefex表示:

    sweet bonanza: sweet bonanza kazanma saatleri – sweet bonanza oyna

  7. Jimmylop表示:

    kraken ru маркетплейс – kraken20 at, сайт кракен тор

  8. JasonUnsoG表示:

    https://slotsiteleri25.com/# slot casino siteleri

  9. JasonUnsoG表示:

    https://denemebonusuverensiteler25.com/# yeni deneme bonusu veren siteler

  10. DanielPooda表示:

    straight from the source phantom wallet

  11. вызвать капельницу от запоя на дому [url=www.vyvod-iz-zapoya-rostov229.ru/]вызвать капельницу от запоя на дому[/url] .

  12. DanielTep表示:

    hop over to this site phantom Extension

  13. DanielTep表示:

    over at this website phantom wallet

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。