透過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...

41,705 Responses

  1. Eugenehaupe表示:

    viagra without a doctor prescription cheap cialis best ed pills non prescription

  2. WilliamSoorp表示:

    https://certifiedpharmacymexico.pro/# medication from mexico pharmacy

  3. WilliamSoorp表示:

    https://medicinefromindia.store/# legitimate online pharmacies india

  4. WilliamSoorp表示:

    https://canadianinternationalpharmacy.pro/# cheap canadian pharmacy online

  5. Eugenehaupe表示:

    ed meds online without doctor prescription best ed pills cheap erectile dysfunction pills

  6. WilliamSoorp表示:

    http://edpill.cheap/# online ed medications

  7. Eugenehaupe表示:

    mexican online pharmacies prescription drugs mexican border pharmacies shipping to usa mexican online pharmacies prescription drugs

  8. Eugenehaupe表示:

    canadian pharmacy online canadian world pharmacy reliable canadian pharmacy reviews

  9. WilliamSoorp表示:

    https://edwithoutdoctorprescription.pro/# buy prescription drugs without doctor

  10. WilliamSoorp表示:

    http://canadianinternationalpharmacy.pro/# online pharmacy canada

  11. Eugenehaupe表示:

    trustworthy canadian pharmacy canadian online pharmacy best canadian pharmacy to order from

  12. WilliamSoorp表示:

    https://edwithoutdoctorprescription.pro/# tadalafil without a doctor’s prescription

  13. Eugenehaupe表示:

    mail order pharmacy india reputable indian pharmacies mail order pharmacy india

  14. WilliamSoorp表示:

    https://edpill.cheap/# best erection pills

  15. Eugenehaupe表示:

    prescription meds without the prescriptions cialis without a doctor prescription ed meds online without doctor prescription

  16. Eugenehaupe表示:

    prescription drugs without doctor approval how to get prescription drugs without doctor viagra without doctor prescription amazon

  17. TerryJuick表示:

    gnc ed pills: best ed pills – cheapest ed pills online

  18. BennyNib表示:

    medications for ed: ed drugs compared – cheap ed drugs

  19. WilliamSoorp表示:

    http://medicinefromindia.store/# online shopping pharmacy india

  20. TerryJuick表示:

    legitimate canadian online pharmacies: best canadian pharmacy online – best canadian online pharmacy

  21. BennyNib表示:

    top 10 pharmacies in india: cheapest online pharmacy india – indian pharmacy online

  22. WilliamSoorp表示:

    http://certifiedpharmacymexico.pro/# mexican rx online

  23. BennyNib表示:

    viagra without a prescription: real viagra without a doctor prescription usa – sildenafil without a doctor’s prescription

  24. TerryJuick表示:

    canadian pharmacy king: canada online pharmacy – legit canadian pharmacy

  25. Eugenehaupe表示:

    ed treatments erection pills viagra online best ed drugs

  26. WilliamSoorp表示:

    https://certifiedpharmacymexico.pro/# mexican pharmaceuticals online

  27. Отличный сайт! Всем рекомендую!1Купить диплом

  28. BennyNib表示:

    ed drugs: medicine erectile dysfunction – ed treatment drugs

發佈留言

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