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

48,232 Responses

  1. Marcobut表示:

    canadian pharmacy checker: Canadian pharmacy best prices – safe canadian pharmacies canadapharm.life

  2. Henrykag表示:

    Online medicine order India pharmacy of the world п»їlegitimate online pharmacies india indiapharm.llc

  3. Marcobut表示:

    indian pharmacy paypal: Medicines from India to USA online – indian pharmacy online indiapharm.llc

  4. Marcobut表示:

    escrow pharmacy canada: Canadian online pharmacy – canadian medications canadapharm.life

  5. BobbyPem表示:

    https://zithromaxbestprice.icu/# can you buy zithromax over the counter in canada

  6. Brucevaf表示:

    cytotec buy online usa: cytotec abortion pill – Misoprostol 200 mg buy online

  7. Brandonjat表示:

    Cytotec 200mcg price buy cytotec over the counter buy cytotec online fast delivery

  8. StevenZen表示:

    buy nolvadex online: tamoxifen generic – nolvadex generic

  9. DavidFrels表示:

    50 mg lisinopril: lisinopril 20 mg tablet – lisinopril 30

  10. BobbyPem表示:

    https://lisinoprilbestprice.store/# lisinopril 20 mg best price

  11. DavidFrels表示:

    Abortion pills online: cytotec abortion pill – buy cytotec pills online cheap

  12. Brandonjat表示:

    buy cytotec over the counter Cytotec 200mcg price cytotec abortion pill

  13. BobbyPem表示:

    https://cytotec.icu/# buy cytotec over the counter

  14. BobbyPem表示:

    https://zithromaxbestprice.icu/# zithromax purchase online

  15. Brandonjat表示:

    п»їcytotec pills online Misoprostol 200 mg buy online п»їcytotec pills online

  16. DavidFrels表示:

    buy nolvadex online: tamoxifen rash pictures – how does tamoxifen work

  17. Brandonjat表示:

    prinivil 25 mg lisinopril 2 mg lisinopril 20 mg daily

  18. Brucevaf表示:

    buy doxycycline 100mg: doxylin – doxy 200

  19. StevenZen表示:

    doxycycline hyclate 100 mg cap: how to buy doxycycline online – doxycycline vibramycin

  20. DavidFrels表示:

    tamoxifen cancer: clomid nolvadex – tamoxifen brand name

  21. BobbyPem表示:

    https://cytotec.icu/# buy cytotec in usa

  22. DavidFrels表示:

    buy cheap doxycycline online: doxycycline hyc – buy doxycycline cheap

  23. Здесь самая качественная порошковая краска алматы. Всем рекомендую!

  24. DavidFrels表示:

    nolvadex generic: tamoxifen and depression – cost of tamoxifen

  25. BobbyPem表示:

    https://cytotec.icu/# cytotec abortion pill

  26. Jamesarill表示:

    https://cytotec.icu/# cytotec online

  27. BobbyPem表示:

    http://doxycyclinebestprice.pro/# where can i get doxycycline

  28. DavidFrels表示:

    Abortion pills online: buy cytotec pills online cheap – buy cytotec over the counter

  29. Jamesarill表示:

    http://lisinoprilbestprice.store/# lisinopril tablets uk

發佈留言

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