透過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,698 Responses

  1. Irvinvef表示:

    http://cipro.guru/# buy cipro cheap

  2. JordanAmoca表示:

    http://cipro.guru/# purchase cipro

  3. Keithfoupt表示:

    diflucan online: how to get diflucan otc – over the counter diflucan pill

  4. RaymondGef表示:

    ciprofloxacin generic price buy generic ciprofloxacin ciprofloxacin

  5. Keithfoupt表示:

    doxycycline 50mg: doxycycline 100mg online – doxycycline 50 mg

  6. JordanAmoca表示:

    https://diflucan.pro/# diflucan without a prescription

  7. JordanAmoca表示:

    https://nolvadex.guru/# tamoxifen effectiveness

  8. Keithfoupt表示:

    cytotec buy online usa: buy cytotec online – buy cytotec in usa

  9. Irvinvef表示:

    https://cytotec24.com/# buy cytotec

  10. RaymondGef表示:

    buy cipro buy cipro online buy cipro

  11. RaymondGef表示:

    buy cytotec online fast delivery buy cytotec online cytotec online

  12. Keithfoupt表示:

    purchase cytotec: buy cytotec pills – buy cytotec pills online cheap

  13. JordanAmoca表示:

    http://nolvadex.guru/# tamoxifen endometriosis

  14. JordanAmoca表示:

    https://doxycycline.auction/# buy cheap doxycycline

  15. Keithfoupt表示:

    buy cytotec over the counter: cytotec buy online usa – cytotec abortion pill

  16. RaymondGef表示:

    buy cytotec in usa cytotec buy online usa п»їcytotec pills online

  17. Irvinvef表示:

    https://nolvadex.guru/# raloxifene vs tamoxifen

  18. Hhlymj表示:

    buy atenolol 50mg generic atenolol 50mg generic buy tenormin cheap

  19. Keithfoupt表示:

    ciprofloxacin order online: ciprofloxacin 500 mg tablet price – ciprofloxacin over the counter

  20. JordanAmoca表示:

    http://doxycycline.auction/# doxycycline

  21. Oiexqv表示:

    ketorolac usa toradol 10mg brand buy colchicine 0.5mg sale

  22. JordanAmoca表示:

    http://diflucan.pro/# how much is a diflucan pill

  23. Keithfoupt表示:

    how to order doxycycline: doxycycline hyclate – buy doxycycline online uk

  24. RaymondGef表示:

    tamoxifen citrate tamoxifen brand name effexor and tamoxifen

  25. RaymondGef表示:

    where to get nolvadex generic tamoxifen should i take tamoxifen

  26. Keithfoupt表示:

    diflucan 150 mg price: can i buy diflucan over the counter in australia – diflucan

  27. JordanAmoca表示:

    http://cipro.guru/# ciprofloxacin 500mg buy online

  28. JordanAmoca表示:

    http://cytotec24.com/# cytotec online

  29. RaymondGef表示:

    tamoxifen blood clots tamoxifen bone density nolvadex for pct

  30. Great site! I recommend to everyone!aimind

發佈留言

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