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

48,082 Responses

  1. RobertJar表示:

    how can i get generic clomid without dr prescription: cost cheap clomid – can i get generic clomid without rx

  2. The Influenza pandemic of 1918 closed local movie theaters and pool halls.

  3. DanielAbice表示:

    https://amoxstar.com/# amoxacillian without a percription

  4. Their professionals have sufficient data about completely different sort of venues.

  5. KennethPah表示:

    india buy prednisone online PredniBest buy prednisone online canada

  6. You can get glass bangles, stainless steel bangles or sterling silver bangles from totally different marketplaces or online retailers.

  7. DanielAbice表示:

    https://clomidonpharm.com/# how to get clomid without rx

  8. Rosman, Katherine (May 10, 2017), “The Property Brothers Are Fixing to Take Over the World” Archived September 22, 2017, on the Wayback Machine.

  9. RobertJar表示:

    how to buy generic clomid: clomid on pharm – can i get clomid pills

  10. KennethPah表示:

    buy amoxicillin canada amoxicillin 500 mg buy amoxicillin 500mg canada

  11. KennethPah表示:

    buy amoxicillin online mexico AmoxStar purchase amoxicillin online

  12. KennethPah表示:

    generic clomid for sale clomidonpharm can i purchase clomid without prescription

  13. RobertJar表示:

    amoxicillin 775 mg: where to get amoxicillin over the counter – amoxicillin 500 mg

  14. Nothing like using a mess to its maximum potential.

  15. DanielAbice表示:

    https://prednibest.com/# prednisone 10mg tabs

  16. BCD Travel is a journey management company working to deliver people collectively to create alternatives for shared experience, dialogue, and development.

  17. светильник уличный на потолок светодиодный светильник уличный на потолок светодиодный .

  18. DanielAbice表示:

    https://cipharmdelivery.com/# cipro pharmacy

  19. уличный светильник светодиодный одуванчик [url=www.svetilnik-svetodiodnyj-ulichnyj.ru]уличный светильник светодиодный одуванчик[/url] .

  20. MiguelUnind表示:

    https://amoxstar.com/# where can i buy amoxicillin over the counter

  21. MiguelUnind表示:

    https://prednibest.com/# buy prednisone no prescription

  22. вина белые [url=https://www.warm-cats.ru]вина белые[/url] .

  23. белое вино в москве https://www.warm-cats.ru .

發佈留言

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