公司要做一個活動頁面,在其過程中發現所有的接口,ajax請求跨域。這裡對跨域做個簡單介紹以及提供幾種解決辦法。
由於浏覽器實現的同源策略的限制,XmlHttpRequest只允許請求當前源(域名、協議、端口)的資源,所以AJAX是不允許跨域的。這裡提供自己常用的三種方法:
1、jsonp訪問
JSONP(JSON with Padding)是一個非官方的協議,它允許在服務器端集成Script tags返回至客戶端,通過javascript callback的形式實現跨域訪問;
實現方式
1)
<script type="text/javascript"> $.ajax({ url:url, dataType:'jsonp', data:'', jsonp:'callback', success:function(result) { }, }); </script>
2)
$.getJSON(url+"?callback=?", function(result) { });
注:1】 jsonp只能用get請求,哪怕你用了post請求,也會自動給你轉換成post;
2】 jsonp 不僅可以用來獲取數據,也可以用來提交數據。
2、damain 方法
在主域相同,子域不同的情況下可以用這種方法,修改域名指向,讓他們指向同一域名,這種辦法也只能解決主域相同而二級域名不同的情況,兩個毫無關系的網址是不可以用這種方法的;
document.domain = 'a.com'
注:在實際開發中,很多人會在本地調試接口,localhost的域名和公司的域名完全不一樣,所有用了domain這種辦法也無法產生效果,解決辦法是修改c盤裡的host文件,把本地地址localhost修改成公司域名或者公司二級域名,然後這種方法就可以使用了。
下面是修改的域名指向:
#127.0.0.1 localhost
127.0.0.1 公司.com
3、postMessage
postMessage是h5的一個新功能之一,由於我們是一家做h5游戲的公司,不可避免的要嵌套iframe,方便數據提交等。
這裡假設,iframe的Id為 ‘iframe';
在iframe裡面的js裡要寫上
var message = 'date';<br>if (parent.document.getElementById(‘iframe‘)) { //捕獲iframe var iframe = parent.document.getElementById(‘iframe').contentWindow; //發送消息 parent.postMessage(message, "*"); }
在iframe外面的js裡要寫上
window.addEventListener('message',function(e){ },false);
然後就可以拿到message的數據了。
以上所述是小編給大家介紹的Ajax跨域的完美解決方案,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!