1. 程式人生 > >JQuery的Ajax跨域請求的解決方案(續)

JQuery的Ajax跨域請求的解決方案(續)

在上篇博文中http://blog.csdn.net/zhouschina/article/details/41721505使用jsonp的方法解決跨域訪問問題。那麼讓我們瞭解一下Jsonp跨域的原理:

jsonp的最基本的原理是:動態新增一個<script>標籤,而script標籤的src屬性是沒有跨域的限制的。這樣說來,這種跨域方式其實與ajax XmlHttpRequest協議無關了. 
這樣其實"jQuery AJAX跨域問題"就成了個偽命題了,jquery $.ajax方法名有誤導人之嫌. 
如果設為dataType: 'jsonp', 這個$.ajax方法就和ajax XmlHttpRequest沒什麼關係了,取而代之的則是JSONP協議. 


JSONP是一個非官方的協議,它允許在伺服器端整合Script tags返回至客戶端,通過javascript callback的形式實現跨域訪問 
JSONP即JSON with Padding。由於同源策略的限制,XmlHttpRequest只允許請求當前源(域名、協議、埠)的資源。如果要進行跨域請求, 
我們可以通過使用html的script標記來進行跨域請求,並在響應中返回要執行的script程式碼,其中可以直接使用JSON傳遞javascript物件。 
這種跨域的通訊方式稱為JSONP。 
jsonCallback 函式jsonp1236827957501(....): 是瀏覽器客戶端註冊的,獲取跨域伺服器上的json資料後,回撥的函式 


明瞭的說Jsonp原理: 
首先在客戶端註冊一個callback (如:'jsoncallback'), 然後把callback的名字(如:jsonp1236827957501)傳給伺服器。 
此時,伺服器先生成 json 資料。 
然後以 javascript 語法的方式,生成一個function , function 名字就是傳遞上來的引數 'jsoncallback'的值 jsonp1236827957501 . 
最後將 json 資料直接以入參的方式,放置到 function 中,這樣就生成了一段 js 語法的文件,返回給客戶端。
客戶端瀏覽器,解析script標籤,並執行返回的 javascript 文件,此時javascript文件資料,作為引數, 

傳入到了客戶端預先定義好的 callback 函式(如上例中jquery $.ajax()方法封裝的的success: function (json))裡.(動態執行回撥函式) 
可以說jsonp的方式原理上和<script src="http://跨域/...xx.js"></script>是一致的(qq空間就是大量採用這種方式來實現跨域資料交換的) .JSONP是一種指令碼注入(Script Injection)行為,所以也有一定的安全隱患. 
注意,jquey是不支援post方式跨域的. 
為什麼呢? 
雖然採用post +動態生成iframe是可以達到post跨域的目的(有位js牛人就是這樣把jquery1.2.5 打patch的),但這樣做是一個比較極端的方式,不建議採用. 
也可以說get方式的跨域是合法的,post方式從安全形度上,被認為是不合法的, 萬不得已還是不要劍走偏鋒.. 
client端跨域訪問的需求看來也引起w3c的注意了,看資料說html5 WebSocket標準支援跨域的資料交換,應該也是一個將來可選的跨域資料交換的解決方案.

使用跨域JQuery傳送請求是瀏覽器會出現如下錯誤

XMLHttpRequest cannot load http://localhost.com/. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access.

解決辦法:在某域名下使用Ajax向另一個域名下的頁面請求資料,會遇到跨域問題。另一個域名必須在response中新增 Access-Control-Allow-Origin 的header,才能讓前者成功拿到資料。

當然這種情況是需要得到另一個網站允許