国产精品爱久久久久久久小说,女人扒开腿让男人桶到爽 ,亚洲欧美国产双大乳头,国产成人精品综合久久久久,国产精品制服丝袜无码,免费无码精品黄av电影,黑色丝袜无码中中文字幕,乱熟女高潮一区二区在线

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

    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è)人資料

    存檔

    主站蜘蛛池模板: 久久日精品| 成人无码视频免费播放| 性亚洲女人色欲色一www| 欧美黄色网络| 国产一区二区精品久久岳| 亚洲一卡2卡3卡4卡精品| 欧美日韩精品| 中文字幕人妻一区二区三区视频| 国产色婷婷亚洲99精品小说| 亚洲日韩中文在线精品第一| 亚洲女人天堂| 91九色在线播放| 亚洲成人影片| 亚洲无av码在线中文字幕| 亚洲国产中文字幕| www.成人.com| 成人AV免费| 亚洲乱码日产精品b| 污视频网站在线观看| 一级在线免费观看| 国产精品一区二区三区专区| 免费人成在线观看播放a| 国产毛片视频| 毛片aaaaa| 无码人妻精品一区二| 亚洲a∨无码精品色午夜| 人妻综合专区第一页| 亚洲综合干| 国产精品无遮挡猛进猛出| 久久综合给合久久狠狠狠97色69| 一卡二卡3卡4卡视频免费播放| 国产精品久久久亚洲| 国产成人精品18| 狠狠色噜噜狠狠狠888777米奇 | 国产伦精品一区二区三区妓女| 国产麻豆精品福利在线观看| 亚洲一区欧美一区| 一极黄色大片| 九九re6热在线视频精品66| 国产精品天天看特色大片| 日韩av专区|