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

  1. Jeromedug表示:

    diflucan 110 mg can i buy diflucan online diflucan over the counter

  2. ArchieAnice表示:

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

  3. RussellVog表示:

    buy doxycycline online 270 tabs: doxycycline 200 mg – buy doxycycline online without prescription

  4. Jeromedug表示:

    ciprofloxacin 500 mg tablet price buy ciprofloxacin over the counter cipro online no prescription in the usa

  5. RussellVog表示:

    doxylin: doxycycline 500mg – odering doxycycline

  6. ArchieAnice表示:

    https://nolvadex.icu/# nolvadex during cycle

  7. Williampiree表示:

    cytotec abortion pill: buy cytotec online – cytotec buy online usa

  8. ArchieAnice表示:

    https://misoprostol.top/# purchase cytotec

  9. Williampiree表示:

    diflucan online purchase uk: can i buy diflucan online – diflucan prices canada

  10. Jeromedug表示:

    buy cipro buy cipro purchase cipro

  11. RussellVog表示:

    diflucan fluconazole: buy diflucan online canada – diflucan order online uk

  12. RussellVog表示:

    doxycycline without a prescription: doxycycline hyclate 100 mg cap – doxycycline

  13. Jamesempiz表示:

    doxycycline: doxycycline 100 mg – price of doxycycline

  14. Jeromedug表示:

    buy cytotec pills online cheap buy cytotec in usa buy cytotec in usa

  15. ArchieAnice表示:

    http://nolvadex.icu/# tamoxifen premenopausal

  16. RussellVog表示:

    buy diflucan otc: buy diflucan pill – diflucan online australia

  17. Jamesempiz表示:

    tamoxifen postmenopausal: nolvadex steroids – tamoxifen for breast cancer prevention

  18. Jeromedug表示:

    generic for doxycycline purchase doxycycline online doxycycline 100mg online

  19. RussellVog表示:

    purchase cytotec: cytotec buy online usa – buy cytotec online fast delivery

  20. Jeromedug表示:

    buy diflucan medicarions how to get diflucan otc diflucan cost in india

  21. Roscoeevern表示:

    https://mexicanpharmgrx.com/# medication from mexico pharmacy

  22. LamarSix表示:

    canadian pharmacy prices: Canada pharmacy online – canadian family pharmacy

  23. LamarSix表示:

    rate canadian pharmacies: My Canadian pharmacy – canadian mail order pharmacy

  24. Roscoeevern表示:

    https://indianpharmgrx.com/# Online medicine order

  25. DavidJeado表示:

    indian pharmacies safe: indian pharmacy delivery – Online medicine order

  26. Roscoeevern表示:

    https://mexicanpharmgrx.com/# best mexican online pharmacies

  27. Larrylab表示:

    mexico drug stores pharmacies Mexico drugstore mexico drug stores pharmacies

  28. LamarSix表示:

    medication from mexico pharmacy: online pharmacy in Mexico – mexico drug stores pharmacies

  29. Отличный сайт! Всем рекомендую, качественный и быстрый ремонт техники! ремонт iphone спб

發佈留言

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