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

  1. Henryfet表示:

    zithromax cost australia: where can i get zithromax over the counter – zithromax antibiotic without prescription

  2. Richardorele表示:

    doxycycline 100mg tablets: buy cheap doxycycline – where to get doxycycline

  3. Отличный сайт! Тут Вы можете приобрестиВоздушные шары

  4. Billyved表示:

    https://gabapentinneurontin.pro/# neurontin canada online

  5. Henryfet表示:

    average cost of prednisone: prednisone 40 mg daily – prednisone 5 mg tablet rx

  6. MarvinRoave表示:

    how to get prednisone without a prescription buy prednisone 20mg prednisone 10 mg price

  7. Henryfet表示:

    prednisone price canada: prednisone 10mg prices – prednisone online sale

  8. MarvinRoave表示:

    zithromax for sale cheap can you buy zithromax over the counter buy zithromax without presc

  9. Apresentando a melhor casa de apostas 1win

  10. Recomendo uma excelente empresa de apostas 1win

  11. Billyved表示:

    http://prednisoned.online/# prednisone 500 mg tablet

  12. Henryfet表示:

    buy cheap prednisone: prescription prednisone cost – buy prednisone 10 mg

  13. Billyved表示:

    http://doxycyclinea.online/# order doxycycline 100mg without prescription

  14. Henryfet表示:

    amoxicillin 250 mg capsule: prescription for amoxicillin – cheap amoxicillin 500mg

  15. Ujfzmi表示:

    cenforce remark – brand viagra online impressive

  16. Richardorele表示:

    neurontin 150mg: neurontin mexico – neurontin india

  17. Charleselila表示:

    order amoxicillin uk: cheap amoxicillin 500mg – amoxicillin 500 mg purchase without prescription

  18. Charleselila表示:

    prednisone 10mg online: prednisone cream over the counter – prednisone for dogs

  19. MarvinRoave表示:

    amoxicillin 500 mg purchase without prescription buying amoxicillin online amoxicillin 500mg cost

  20. Escolha de uma casa de apostas confiavel 1win

  21. Melhor site de apostas, recomendado 1win

  22. Charleselila表示:

    amoxicillin online pharmacy: buy amoxicillin online cheap – prescription for amoxicillin

  23. Billyved表示:

    https://doxycyclinea.online/# doxycycline without prescription

  24. Henryfet表示:

    prednisone 20mg nz: prednisone 20mg – prednisone prescription online

  25. MarvinRoave表示:

    amoxicillin 500mg buy online uk amoxicillin price without insurance amoxicillin 500mg tablets price in india

  26. Henryfet表示:

    prednisone price australia: prednisone 475 – prednisone pills for sale

  27. MarvinRoave表示:

    zithromax cost canada generic zithromax 500mg india buy generic zithromax online

  28. MarvinRoave表示:

    how to order doxycycline buy doxycycline without prescription online doxycycline

  29. Henryfet表示:

    neurontin price australia: medicine neurontin – canada where to buy neurontin

  30. Billyved表示:

    http://gabapentinneurontin.pro/# neurontin cost in singapore

發佈留言

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