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

  1. JamesCof表示:

    1 mg prednisone cost: prednisone 54899 – prednisone 40 mg

  2. Charlesdix表示:

    https://buyprednisone.store/# where can you buy prednisone

  3. JamesCof表示:

    furosemide: furosemide 100 mg – lasix

  4. Stephenpem表示:

    https://furosemide.guru/# lasix 40 mg

  5. DavidRak表示:

    buy lasix online Buy Lasix No Prescription lasix tablet

  6. LeonardFaulk表示:

    lisinopril generic price comparison: lisinopril – lisinopril 40mg

  7. JamesCof表示:

    lasix uses: lasix tablet – furosemida 40 mg

  8. Charlesdix表示:

    https://amoxil.cheap/# amoxicillin 500 mg purchase without prescription

  9. Charlesdix表示:

    https://amoxil.cheap/# buy amoxicillin 500mg usa

  10. Great site! I recommend to everyone!us stocks ranking

  11. JamesCof表示:

    prednisone 500 mg tablet: buy prednisone without a prescription best price – prednisone 40 mg

  12. JamesCof表示:

    amoxicillin 500mg prescription: buy amoxicillin 500mg – amoxicillin 750 mg price

  13. DavidRak表示:

    amoxicillin 200 mg tablet buy amoxicillin online without prescription buy amoxicillin

  14. LeonardFaulk表示:

    stromectol covid 19: ivermectin 3 mg dose – stromectol 12mg

  15. DavidRak表示:

    buy amoxicillin online uk amoxicillin 500mg buy online uk buy amoxicillin online mexico

  16. Charlesdix表示:

    http://amoxil.cheap/# amoxicillin 500 mg price

  17. JamesCof表示:

    lasix 100 mg: Buy Lasix No Prescription – lasix furosemide

  18. Charlesdix表示:

    https://furosemide.guru/# generic lasix

  19. DavidRak表示:

    lasix pills Buy Lasix No Prescription lasix 20 mg

  20. Stephenpem表示:

    http://amoxil.cheap/# how much is amoxicillin

  21. JamesCof表示:

    cost of ivermectin pill: ivermectin 8000 mcg – where to buy ivermectin

  22. LeonardFaulk表示:

    lisinopril 40 mg brand name: prinivil brand name – lisinopril 20 mg prices

  23. JamesCof表示:

    amoxicillin no prescipion: amoxicillin generic – amoxicillin 250 mg price in india

  24. Charlesdix表示:

    http://furosemide.guru/# furosemide

  25. Charlesdix表示:

    https://lisinopril.top/# lisinopril buy online

  26. JamesCof表示:

    lasix 100mg: Buy Lasix – furosemide 40 mg

  27. Stephenpem表示:

    http://buyprednisone.store/# 15 mg prednisone daily

  28. DavidRak表示:

    buy lasix online Buy Furosemide furosemide 40 mg

  29. Pbcqcb表示:

    order xenical 60mg online cheap xenical 120mg cost buy cheap generic diltiazem

  30. JamesCof表示:

    prednisone for sale no prescription: prednisone 10 mg price – purchase prednisone no prescription

發佈留言

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