透過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...

43,714 Responses

  1. Thomasgelty表示:

    http://angelawhite.pro/# Angela White video

  2. Thomasgelty表示:

    https://sweetiefox.online/# sweeti fox

  3. EddieDor表示:

    http://lanarhoades.fun/# lana rhodes

  4. JamesDiect表示:

    Angela White: abella danger filmleri – abella danger izle

  5. JamesDiect表示:

    eva elfie filmleri: eva elfie modeli – eva elfie filmleri

  6. RodrigoJet表示:

    http://sweetiefox.online/# Sweetie Fox filmleri

  7. RodrigoJet表示:

    https://abelladanger.online/# abella danger izle

  8. Thomasgelty表示:

    https://sweetiefox.online/# Sweetie Fox izle

  9. Thomasgelty表示:

    http://sweetiefox.online/# sweeti fox

  10. JamesDiect表示:

    Angela White filmleri: abella danger video – Abella Danger

  11. EddieDor表示:

    http://abelladanger.online/# abella danger video

  12. RodrigoJet表示:

    http://evaelfie.pro/# eva elfie filmleri

  13. Chiller1obliz表示:

    Здесь вы найдете очень качественный чиллер от производителя

  14. Thomasgelty表示:

    https://sweetiefox.online/# swetie fox

  15. JamesDiect表示:

    eva elfie izle: eva elfie – eva elfie

  16. Thomasgelty表示:

    https://lanarhoades.fun/# lana rhoades filmleri

  17. JamesDiect表示:

    eva elfie modeli: eva elfie video – eva elfie filmleri

  18. RodrigoJet表示:

    https://sweetiefox.online/# Sweetie Fox modeli

  19. EddieDor表示:

    http://lanarhoades.fun/# lana rhoades modeli

  20. JamesDiect表示:

    lana rhoades izle: lana rhoades modeli – lana rhoades filmleri

  21. Thomasgelty表示:

    http://evaelfie.pro/# eva elfie izle

  22. RodrigoJet表示:

    https://lanarhoades.fun/# lana rhodes

  23. Thomasgelty表示:

    https://evaelfie.pro/# eva elfie video

  24. JamesDiect表示:

    ?????? ????: abella danger video – abella danger filmleri

  25. JamesDiect表示:

    Sweetie Fox modeli: Sweetie Fox filmleri – Sweetie Fox filmleri

  26. RodrigoJet表示:

    https://abelladanger.online/# abella danger filmleri

  27. Thomasgelty表示:

    http://lanarhoades.fun/# lana rhoades modeli

  28. Thomasgelty表示:

    http://abelladanger.online/# abella danger filmleri

發佈留言

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