透過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. William Ernest Lawrence, Accountant, Revenue and Enterprise Undertakings, Division of the Inside.

  2. Aw, this was an incredibly nice post. Taking a few minutes and actual effort to generate a good article… but what can I say… I procrastinate a lot and never seem to get nearly anything done.

  3. BrandenSlomy表示:

    cheap clomid: clomid online – buy generic clomid prices

  4. 最悪の日表示:

    Audrey Brontilla Henry. For public service.

  5. Any use of the land should wait until external radiation levels are low sufficient for individuals to work safely outdoors.

  6. She is preceded in demise by her husband Cook Broadway Conn; sister, Alice Smith, brothers; John “Paton” Blake and James “Jim” Allen Blake.

  7. Bradleygoath表示:

    buy prednisone tablets uk prednisone in uk can i order prednisone

  8. Earlier than the final rules have been issued, many questions remained as to how broadly the ATB definition could be utilized.

  9. Предлагаем услуги профессиональных инженеров офицальной мастерской.
    Еслли вы искали сервисный центр xiaomi, можете посмотреть на сайте: сервисный центр xiaomi
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  10. Danieljek表示:

    buy amoxicillin online uk http://amoxilcompharm.com/# buy amoxicillin 500mg capsules uk

  11. Bradleygoath表示:

    order generic clomid for sale rex pharm how to get cheap clomid

  12. Step 3: Using white paint, paint a smaller circle (the snowman’s head) resting on top of the bottom circle.

  13. StevenNub表示:

    where to buy generic clomid pills: can i order generic clomid without dr prescription – order clomid no prescription

  14. Danieljek表示:

    azithromycin amoxicillin http://clomidrexpharm.com/# cost generic clomid no prescription

  15. StevenNub表示:

    where to buy cheap clomid pill: buy clomid – can i order generic clomid without dr prescription

  16. You don’t want a stockbroker as of late, although.

  17. Danieljek表示:

    amoxicillin discount http://priligymaxpharm.com/# buy priligy

  18. New and rising waste therapy technologies comparable to mechanical biological treatment might supply an alternative to kerbside assortment by way of automated separation of waste in recycling factories.

  19. вывод из запоя ростов и область http://www.uaforum.ukrbb.net/viewtopic.php?f=13&t=3230 .

  20. срочный вывод из запоя ростов ukroenergo.ukrbb.net/viewtopic.php?f=13&t=21376 .

  21. BrandenSlomy表示:

    priligy max pharm: Priligy tablets – Priligy tablets

  22. StevenNub表示:

    where can i get cheap clomid pill: can i purchase cheap clomid no prescription – how can i get generic clomid

  23. BrandenSlomy表示:

    how to buy clomid online: rex pharm – can you buy generic clomid

  24. BrandenSlomy表示:

    amoxicillin capsules 250mg: com pharm – amoxicillin 200 mg tablet

  25. StevenNub表示:

    where buy clomid prices: generic clomid – can i purchase generic clomid online

發佈留言

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