濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > Ajax跨域的完美解決方案

Ajax跨域的完美解決方案

熱門標(biāo)簽:怎樣在地圖標(biāo)注文字 東平縣地圖標(biāo)注app 上海企業(yè)外呼系統(tǒng)價(jià)錢 地圖標(biāo)注推銷坑人 大眾點(diǎn)評(píng)400電話怎么申請(qǐng) 河間市地圖標(biāo)注app 電銷機(jī)器人 長春 中國地圖標(biāo)注不明確情況介紹表 立陶宛地圖標(biāo)注

公司要做一個(gè)活動(dòng)頁面,在其過程中發(fā)現(xiàn)所有的接口,ajax請(qǐng)求跨域。這里對(duì)跨域做個(gè)簡單介紹以及提供幾種解決辦法。

  由于瀏覽器實(shí)現(xiàn)的同源策略的限制,XmlHttpRequest只允許請(qǐng)求當(dāng)前源(域名、協(xié)議、端口)的資源,所以AJAX是不允許跨域的。這里提供自己常用的三種方法:

1、jsonp訪問

  JSONP(JSON with Padding)是一個(gè)非官方的協(xié)議,它允許在服務(wù)器端集成Script tags返回至客戶端,通過javascript callback的形式實(shí)現(xiàn)跨域訪問;

實(shí)現(xiàn)方式

  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請(qǐng)求,哪怕你用了post請(qǐng)求,也會(huì)自動(dòng)給你轉(zhuǎn)換成post;

  2】 jsonp 不僅可以用來獲取數(shù)據(jù),也可以用來提交數(shù)據(jù)。

2、damain 方法

  在主域相同,子域不同的情況下可以用這種方法,修改域名指向,讓他們指向同一域名,這種辦法也只能解決主域相同而二級(jí)域名不同的情況,兩個(gè)毫無關(guān)系的網(wǎng)址是不可以用這種方法的;

document.domain = 'a.com'

注:在實(shí)際開發(fā)中,很多人會(huì)在本地調(diào)試接口,localhost的域名和公司的域名完全不一樣,所有用了domain這種辦法也無法產(chǎn)生效果,解決辦法是修改c盤里的host文件,把本地地址localhost修改成公司域名或者公司二級(jí)域名,然后這種方法就可以使用了。

下面是修改的域名指向:

#127.0.0.1  localhost
127.0.0.1   公司.com

3、postMessage

  postMessage是h5的一個(gè)新功能之一,由于我們是一家做h5游戲的公司,不可避免的要嵌套iframe,方便數(shù)據(jù)提交等。

  這里假設(shè),iframe的Id為 ‘iframe';

  在iframe里面的js里要寫上

var message = 'date';br>if (parent.document.getElementById(‘iframe‘)) {
          //捕獲iframe
          var iframe = parent.document.getElementById(‘iframe').contentWindow;
          //發(fā)送消息
          parent.postMessage(message, "*");
        }

  在iframe外面的js里要寫上

window.addEventListener('message',function(e){
      },false);

  然后就可以拿到message的數(shù)據(jù)了。

以上所述是小編給大家介紹的Ajax跨域的完美解決方案,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • jQuery.ajax 跨域請(qǐng)求webapi設(shè)置headers的解決方案
  • IE9 IE8 ajax跨域問題的快速解決方法
  • 使用Nginx 反向代理來避免 ajax 跨域請(qǐng)求的方法
  • Python的Django應(yīng)用程序解決AJAX跨域訪問問題的方法
  • Ajax跨域問題的解決辦法匯總(推薦)
  • 深入淺析Jsonp解決ajax跨域問題
  • Ajax 跨域如何實(shí)現(xiàn)

標(biāo)簽:本溪 益陽 銅川 遼寧 玉樹 內(nèi)江 四川 營口

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ajax跨域的完美解決方案》,本文關(guān)鍵詞  Ajax,跨域,的,完美,解決方案,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ajax跨域的完美解決方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于Ajax跨域的完美解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    梁山县| 句容市| 衡水市| 闵行区| 禹城市| 贵港市| 云梦县| 乐东| 临高县| 郁南县| 靖安县| 农安县| 定襄县| 象州县| 迁安市| 唐山市| 南京市| 瓮安县| 肃南| 锡林郭勒盟| 顺义区| 郁南县| 嵩明县| 开阳县| 浙江省| 陆河县| 宣恩县| 大新县| 龙里县| 乌兰察布市| 抚松县| 安达市| 青海省| 纳雍县| 禹城市| 丽水市| 宁陕县| 新闻| 朝阳县| 闵行区| 沁阳市|