国产69囗曝吞精在线视频,肥臀浪妇太爽了快点再快点,亚洲欧洲成人a∨在线观看,狠狠色丁香久久综合 ,国精一二二产品无人区免费应用,亚洲精品久久久久中文字幕,四虎一区二区成人免费影院网址 ,无码三级中文字幕在线观看

      前端解決跨域問題的常用方法

      2019-11-6    seo達(dá)人

      首先,跨域是什么?



      只要協(xié)議、域名、端口有任何一個(gè)不同,都被當(dāng)作是不同的域。為什么三者任何一個(gè)不同就會(huì)產(chǎn)生跨域呢,想想也很容易知道,要是很隨便引用什么外部文件,不同標(biāo)簽下的頁面引用類似的彼此的文件,瀏覽器很容易懵逼的,保障不了安全問題,但在安全限制的同時(shí)也給注入iframe或是ajax請(qǐng)求上帶來了不少麻煩。所以我們要通過一些方法使本域的js能夠操作其他域的頁面對(duì)象或者使其他域的js能操作本域的頁面對(duì)象



      但有兩點(diǎn)至少要清楚:



      如果是協(xié)議和端口造成的跨域問題“前臺(tái)”是無能為力的;

      在跨域問題上,域僅僅是通過“URL的首部”來識(shí)別而不會(huì)去嘗試判斷相同的ip地址對(duì)應(yīng)著兩個(gè)域或兩個(gè)域是否在同一個(gè)ip上。

      (“URL的首部”指window.location.protocol +window.location.host,也可以理解為“Domains, protocols and ports must match”。)

      1.通過HTML5的postMessage方法跨域



      頁面M通過postMessage方法發(fā)送消息如下:



      window.onload = function() {  

          var iframe_dom = document.getElementById('iframId');  

          var targetOrigin = ";

          iframe_dom.contentWindow.postMessage('hello world!', targetOrigin);  

      };

      備注:



      postMessage的使用方法:



      originwindow.postMessage(message, targetOrigin);



      originwindow:是說的目標(biāo)窗口,即要給某個(gè)window發(fā)消息,是 window.frames 屬性的成員或者由 window.open 方法創(chuàng)建的窗口

      message: 是要發(fā)送的消息,類型為 String、Object (但I(xiàn)E8、9 不支持)

      targetOrigin: 是限定消息接收范圍,不限制請(qǐng)使用 '*

      頁面N通過message事件監(jiān)聽并接受消息如下:



      let onmessage = function (event) {  

        var data = event.data;//由發(fā)送窗口傳過來的消息內(nèi)容  

        var origin = event.origin;//由發(fā)送窗口傳過來的消息來源地址  

        var source = event.source;//源Window對(duì)象  

        if(origin=="
      ;

          console.log(data);//hello world!  

        }  

      };  

      if (typeof window.addEventListener != 'undefined') {  

        window.addEventListener('message', onmessage, false);  

      } else if (typeof window.attachEvent != 'undefined') {  

        //for ie  

        window.attachEvent('onmessage', onmessage);  

      }

      或者為了防止接入方的命名沖突,也可以約定事件名,以此加以區(qū)分



      例如



      window.addEventListener("message", function(event) {

        if (

          event &&

          typeof event.data == "object" &&

          event.data.event == "FUNCTION_NAME"

      ){

      document.getElementById("val").innerHTML = event.data.value;

      } });

      2.通過JSONP



      上面那種方式的通信是雙向的,頁面與iframe或是頁面與頁面之間的



      JSONP主要是封裝好的請(qǐng)求方式添加callback,這個(gè)callback是由前后端約定好的



      它的優(yōu)劣勢(shì):



      JSONP的優(yōu)點(diǎn):它不像XMLHttpRequest對(duì)象實(shí)現(xiàn)的Ajax請(qǐng)求那樣受到同源策略的限制;它的兼容性更好,在更加古老的瀏覽器中都可以運(yùn)行,不需要XMLHttpRequest或ActiveX的支持;并且在請(qǐng)求完畢后可以通過調(diào)用callback的方式回傳結(jié)果。

      JSONP的缺點(diǎn):它只支持GET請(qǐng)求而不支持POST等其它類型的HTTP請(qǐng)求;它只支持跨域HTTP請(qǐng)求這種情況,不能解決不同域的兩個(gè)頁面之間如何進(jìn)行JavaScript調(diào)用的問題;無法判斷它是否請(qǐng)求成功,只能通過timeout

      3.CORS跨域



      實(shí)現(xiàn)CORS通信的關(guān)鍵是服務(wù)器端,只要服務(wù)端那邊實(shí)現(xiàn)了CORS接口,就可以跨源通信



      CORS(Cross-Origin Resource Sharing)跨域資源共享,定義了必須在訪問跨域資源時(shí),瀏覽器與服務(wù)器應(yīng)該如何溝通。CORS背后的基本思想就是使用自定義的HTTP頭部讓瀏覽器與服務(wù)器進(jìn)行溝通,從而決定請(qǐng)求或響應(yīng)是應(yīng)該成功還是失敗。目前,所有瀏覽器都支持該功能,IE瀏覽器不能低于IE10。整個(gè)CORS通信過程,都是瀏覽器自動(dòng)完成,不需要用戶參與。對(duì)于開發(fā)者來說,CORS通信與同源的AJAX通信沒有差別,代碼完全一樣。瀏覽器一旦發(fā)現(xiàn)AJAX請(qǐng)求跨源,就會(huì)自動(dòng)添加一些附加的頭信息,有時(shí)還會(huì)多出一次附加的請(qǐng)求,但用戶不會(huì)有感覺



      服務(wù)器端對(duì)于CORS的支持,主要就是通過設(shè)置Access-Control-Allow-Origin來進(jìn)行的。如果瀏覽器檢測(cè)到相應(yīng)的設(shè)置,便可以允許Ajax進(jìn)行跨域的訪問



       



      CORS和JSONP對(duì)比



      JSONP只能實(shí)現(xiàn)GET請(qǐng)求,而CORS支持所有類型的HTTP請(qǐng)求。



      使用CORS,開發(fā)者可以使用普通的XMLHttpRequest發(fā)起請(qǐng)求和獲得數(shù)據(jù),比起JSONP有更好的錯(cuò)誤處理。



      JSONP主要被老的瀏覽器支持,它們往往不支持CORS,而絕大多數(shù)現(xiàn)代瀏覽器都已經(jīng)支持了CORS)。



      CORS與JSONP相比,顯然更為先進(jìn)、方便和可靠。



      4.設(shè)置代理



      目前市場(chǎng)上用vue技術(shù)不在少數(shù),下面介紹一種配置代理方式



      在vue.config.js該文件里面配置如下:



       devServer: {

              port: 8001,

              open: true,

              disableHostCheck: true,

              proxy: {

                  '/api': {

                      target: 'https:/xxx.com',

                      secure: true, // false為http訪問,true為https訪問

                      ws: true,

                      changeOrigin: true,

                      pathRewrite: {

                          '^/api': ''

                      }

                   }

              }

       }

       



      后面請(qǐng)求是需要帶上‘/api’請(qǐng)求即可


      日歷

      鏈接

      個(gè)人資料

      存檔

      主站蜘蛛池模板: 糖心视频在线| 中文无码久久精品| 激情综合一区二区迷情校园| 免费在线视频观看| 18禁无遮拦无码国产在线播放| 久久久无码精品亚洲日韩电影| 又色又爽又黄gif动态图| 特级大胆西西4444人体| 日本特黄特黄刺激大片| 高潮迭起av乳颜射后入| 日本国产在线| 国产精品老牛影视| 人妻熟女一二三区夜夜爱| 97久久超碰福利国产精品…| 精品无人区无码乱码毛片国产| 国产欧美日韩久久| 欧美巨大巨粗黑人性aaaaaa| 亚洲r成人av久久人人爽澳门赌 | 国产a免费视频| 精品无码久久久久久久久| 中文字幕亚洲日韩无线码| 在线观看免费高清在线观看| 手机看片午夜| 亚洲一区精品二人人爽久久| 无码人妻日韩一区日韩二区 | 不卡一区二区视频日本| 免费成人看片| 欧美午夜精品久久久| 97se亚洲精品一区| 可以免费观看的av毛片下载| 亚洲成人福利| 日韩欧美网址| 国内少妇人妻丰满av| 男女性高爱潮是免费国产| 五月天婷婷色| 宇都宫紫苑在线播放| 日韩成人无码| 欧美精品一国产成人综合久久| 91久久| 亚洲最新av网站| www射我里面在线观看|