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

  1. CharlesEmpit表示:

    canadian pharmacy ltd cheapestcanada.com best mail order pharmacy canada

  2. CharlesEmpit表示:

    Online medicine home delivery indianpharmacy com indianpharmacy com

  3. Jimmielic表示:

    http://36and6health.com/# cheapest pharmacy to fill prescriptions with insurance

  4. CharlesEmpit表示:

    buy prescription drugs from india world pharmacy india buy medicines online in india

  5. StevenPably表示:

    https://cheapestandfast.shop/# canadian pharmacy online no prescription needed

  6. StevenPably表示:

    https://cheapestcanada.shop/# canadian 24 hour pharmacy

  7. Um cassino com a melhor reputacao Blaze

  8. Terryclews表示:

    mail order prescriptions from canada: cheapest & fast pharmacy – non prescription online pharmacy india

  9. CharlesEmpit表示:

    canadian pharmacy mall cheapest canada canadian pharmacy prices

  10. StevenPably表示:

    http://cheapestandfast.com/# canadian pharmacy no prescription needed

  11. StevenPably表示:

    https://cheapestindia.shop/# buy medicines online in india

  12. Experimente o melhor cassino Blaze

  13. Descubra o melhor cassino Blaze

  14. Jimmielic表示:

    http://cheapestindia.com/# top 10 pharmacies in india

  15. Roberthaish表示:

    propecia cost: generic propecia tablets – propecia without insurance

  16. Marvinteabs表示:

    generic clomid without a prescription can you buy cheap clomid prices can i order clomid pills

  17. Robertbup表示:

    https://propeciaf.online/# propecia tablets

  18. Thomasallop表示:

    buy generic clomid without dr prescription: clomid generics – where can i buy generic clomid pills

  19. Robertbup表示:

    http://clomiphene.shop/# how to get clomid price

  20. Thomasallop表示:

    can i get cheap clomid without prescription: can i order cheap clomid – buy generic clomid no prescription

  21. Robertbup表示:

    http://propeciaf.online/# cost cheap propecia prices

  22. Robertbup表示:

    https://cytotec.xyz/# buy cytotec online fast delivery

  23. Ahaa, its pleasant dialogue on the topic of this
    paragraph at this place at this web site, I have read all
    that, so at this time me also commenting at this place.

    Here is my blog post … facebook vs eharmony to find love online

  24. Marvinteabs表示:

    neurontin cap 300mg price neurontin 400 mg cost neurontin 214

  25. Roberthaish表示:

    how to get cheap clomid prices: cost of generic clomid without prescription – where can i buy clomid no prescription

  26. Thomasallop表示:

    lisinopril cheap price: 40 mg lisinopril for sale – zestoretic 20 25

  27. Robertbup表示:

    http://clomiphene.shop/# where buy clomid

  28. Marvinteabs表示:

    buying neurontin online prescription price for neurontin neurontin 300 mg mexico

  29. Thomasallop表示:

    neurontin for sale: neurontin without prescription – neurontin 100 mg tablets

  30. Thomasallop表示:

    Abortion pills online: purchase cytotec – cytotec abortion pill

發佈留言

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