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

  1. Jameswaw表示:

    amoxicillin online purchase amoxicillin generic buy amoxicillin 500mg capsules uk

  2. JosephBix表示:

    https://azithromycina.pro/# zithromax z-pak

  3. DomenicEcoff表示:

    no prescription prednisone canadian pharmacy: can i purchase prednisone without a prescription – prednisone 50 mg buy

  4. JosephBix表示:

    http://clomida.pro/# can i order generic clomid for sale

  5. Jameswaw表示:

    zithromax 600 mg tablets zithromax online usa no prescription zithromax online usa

  6. Michaelhig表示:

    how can i get cheap clomid price: where to buy cheap clomid no prescription – can i get generic clomid without prescription

  7. Jameswaw表示:

    stromectol price us stromectol tablets uk cost of ivermectin 1% cream

  8. Michaelhig表示:

    stromectol south africa: stromectol buy – cost of ivermectin pill

  9. Jameswaw表示:

    where can i buy zithromax in canada buy zithromax canada zithromax antibiotic

  10. RussellVog表示:

    buy cytotec online: buy cytotec over the counter – purchase cytotec

  11. RussellVog表示:

    doxycycline generic: doxycycline generic – doxycycline 100mg capsules

  12. Williampiree表示:

    purchase diflucan: diflucan 200mg tab – order diflucan online cheap

  13. ArchieAnice表示:

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

  14. Williampiree表示:

    buy cipro online: п»їcipro generic – purchase cipro

  15. Jeromedug表示:

    diflucan cost uk can i buy diflucan online diflucan tablet india

  16. Отличный сайт! Всем рекомендую! выезд нотариуса на дом

  17. RussellVog表示:

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

  18. RussellVog表示:

    buy cipro cheap: ciprofloxacin generic price – cipro for sale

  19. Jeromedug表示:

    buy cytotec online cytotec buy online usa Abortion pills online

  20. ArchieAnice表示:

    https://ciprofloxacin.guru/# cipro ciprofloxacin

  21. Jamesempiz表示:

    cytotec online: order cytotec online – buy cytotec in usa

  22. RussellVog表示:

    diflucan no prescription: diflucan 110 mg – diflucan 150 mg caps

  23. RussellVog表示:

    diflucan tablets online: diflucan oral – buy diflucan without prescription

  24. Jeromedug表示:

    does tamoxifen make you tired common side effects of tamoxifen alternatives to tamoxifen

  25. Jeromedug表示:

    doxycycline hyclate 100 mg cap buy doxycycline online uk doxycycline tablets

  26. современный центр медицины комбинированного типа表示:

    московское медицинское учреждение Здоровье купить справку медицинскую в Москве купить справку из медцентра

  27. Jeromedug表示:

    cytotec pills buy online buy cytotec buy cytotec in usa

  28. Jamesempiz表示:

    cost of tamoxifen: common side effects of tamoxifen – liquid tamoxifen

  29. Williampiree表示:

    ciprofloxacin mail online: cipro – cipro 500mg best prices

  30. RussellVog表示:

    tamoxifen warning: nolvadex for sale – tamoxifen

發佈留言

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