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

  1. I’m new to your blog and i really appreciate the nice posts and great layout.~,”:*

  2. Jaimevoink表示:

    best generic lisinopril can you buy lisinopril lisinopril cost us

  3. Jaimevoink表示:

    can i buy generic clomid online can i order cheap clomid without a prescription can i get cheap clomid prices

  4. Gucci Handbags When can you post again? You actually inform lots of folks!

  5. RobertUnmab表示:

    can i order cheap clomid prices: where buy clomid prices – order generic clomid no prescription

  6. ArmandoDat表示:

    cost of cheap clomid pills: order cheap clomid now – can you buy clomid without insurance

  7. ArmandoDat表示:

    ciprofloxacin 500 mg tablet price: buy cipro online usa – ciprofloxacin 500mg buy online

  8. JimmieTup表示:

    https://cytotec.top/# cytotec buy online usa

  9. Jaimevoink表示:

    purchase cytotec buy cytotec online buy cytotec pills online cheap

  10. ArmandoDat表示:

    lisinopril 40 mg tablet price: lisinopril online – can i buy lisinopril over the counter in canada

  11. Jaimevoink表示:

    where can i buy cipro online antibiotics cipro cipro pharmacy

  12. ArmandoDat表示:

    buy cytotec pills: cytotec pills buy online – Abortion pills online

  13. RobertUnmab表示:

    zestoretic 10 12.5 mg: lisinopril metoprolol – lisinopril mexico

  14. Slottica PL表示:

    I will right away grab your rss feed as I can not find your e-mail subscription link or e-newsletter service. Do you’ve any? Please let me know so that I could subscribe. Thanks.

  15. JimmieTup表示:

    http://cytotec.top/# purchase cytotec

  16. RobertUnmab表示:

    where to buy generic clomid now: how can i get clomid tablets – how can i get clomid for sale

  17. RobertUnmab表示:

    cytotec abortion pill: Abortion pills online – Abortion pills online

  18. выведение из запоя на дому круглосуточно выведение из запоя на дому круглосуточно .

  19. Jaimevoink表示:

    lisinopril best price cost of brand name lisinopril lisinopril 5mg tab

  20. ArmandoDat表示:

    buy zithromax 500mg online: zithromax 500 without prescription – buy zithromax canada

  21. JimmieTup表示:

    https://ciprofloxacin.cheap/# buy ciprofloxacin over the counter

  22. JimmieTup表示:

    https://lisinoprilus.com/# purchase lisinopril

  23. JimmieTup表示:

    https://ciprofloxacin.cheap/# buy ciprofloxacin over the counter

發佈留言

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