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

  1. MarvinRoave表示:

    amoxicillin 500mg prescription buy amoxicillin online mexico amoxicillin medicine

  2. Charleselila表示:

    50 mg prednisone tablet: buy prednisone 1 mg mexico – buying prednisone

  3. MarvinRoave表示:

    zithromax online pharmacy canada can i buy zithromax over the counter in canada where can i get zithromax over the counter

  4. MarvinRoave表示:

    prednisone 50 mg canada prednisone 21 pack prednisone 20mg for sale

  5. Henryfet表示:

    drug prices prednisone: prednisone price south africa – prednisone 10 mg coupon

  6. MarvinRoave表示:

    can i buy prednisone over the counter in usa prednisone 5mg over the counter cheapest prednisone no prescription

  7. Henryfet表示:

    amoxicillin no prescipion: amoxicillin online no prescription – buy amoxicillin 500mg online

  8. Richardorele表示:

    doxycycline hyc: buy doxycycline 100mg – 100mg doxycycline

  9. Billyved表示:

    https://zithromaxa.store/# zithromax online pharmacy canada

  10. Henryfet表示:

    amoxicillin over counter: where can i buy amoxicillin without prec – where to buy amoxicillin 500mg

  11. Henryfet表示:

    zithromax: where can i buy zithromax uk – cost of generic zithromax

  12. Richardorele表示:

    doxycycline pills: price of doxycycline – how to buy doxycycline online

  13. Billyved表示:

    http://amoxila.pro/# amoxicillin 500mg for sale uk

  14. Richardorele表示:

    medication neurontin 300 mg: neurontin prescription online – neurontin 204

  15. Billyved表示:

    http://amoxila.pro/# how to buy amoxycillin

  16. MarvinRoave表示:

    purchase zithromax online buy zithromax without prescription online buy zithromax online fast shipping

  17. MarvinRoave表示:

    antibiotic amoxicillin azithromycin amoxicillin buy amoxicillin 500mg online

  18. Отличный сайт! Тут Вы можете найтимайнкрафт сервера

  19. Henryfet表示:

    prednisone buy without prescription: prednisone buy – prednisone 10 mg price

  20. MarvinRoave表示:

    amoxil generic amoxicillin 500 mg without a prescription amoxicillin for sale

  21. Henryfet表示:

    buy doxycycline online: doxycycline tetracycline – doxycycline hyc

  22. Muysex表示:

    viagra professional online goodness – viagra professional online suffer levitra oral jelly captain

  23. Billyved表示:

    http://gabapentinneurontin.pro/# neurontin 300 mg capsule

  24. Henryfet表示:

    zithromax for sale 500 mg: zithromax 500mg – zithromax 250 mg tablet price

  25. Henryfet表示:

    buy neurontin 100 mg: neurontin prices generic – neurontin generic brand

  26. Richardorele表示:

    order amoxicillin online no prescription: amoxicillin pills 500 mg – amoxicillin no prescription

  27. MarvinRoave表示:

    neurontin 600 buy generic neurontin online neurontin 300 mg coupon

  28. Charleselila表示:

    generic amoxicillin 500mg: buy cheap amoxicillin – amoxicillin 500mg capsules price

  29. Charleselila表示:

    where can i buy zithromax capsules: zithromax 1000 mg pills – how to get zithromax over the counter

發佈留言

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