亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue學(xué)習(xí)筆記之跨域的6種解決方案

 更新時(shí)間:2024年04月13日 10:26:39   作者:??千帆??、  
在前后端分離項(xiàng)目中,跨域是一定會(huì)出現(xiàn)的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于Vue學(xué)習(xí)筆記之跨域的6種解決方案,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

一、跨域是什么?

跨域問(wèn)題指的是在瀏覽器端,當(dāng)一個(gè)網(wǎng)頁(yè)的腳本(如JavaScript)向另一個(gè)域名的網(wǎng)站發(fā)起請(qǐng)求時(shí),如果兩個(gè)網(wǎng)站的域名不一致,就會(huì)出現(xiàn)跨域問(wèn)題。由于瀏覽器的同源策略(Same Origin Policy),默認(rèn)情況下,腳本只能訪問(wèn)同一個(gè)域名下的資源,不能訪問(wèn)其他域名下的資源。

二、跨域問(wèn)題的解決方法

1.JSONP

JSONP (JSON with Padding) 是一種在客戶端與服務(wù)器之間進(jìn)行跨域數(shù)據(jù)傳輸?shù)慕鉀Q方案,它利用了

2.Nginx反向代理

Nginx是一款高性能的Web服務(wù)器和反向代理服務(wù)器,可以用于解決跨域問(wèn)題。具體實(shí)現(xiàn)方法是在Nginx的配置文件中添加反向代理規(guī)則,將請(qǐng)求轉(zhuǎn)發(fā)到目標(biāo)服務(wù)器,并將響應(yīng)返回給客戶端。
下面是一個(gè)簡(jiǎn)單的Nginx反向代理配置示例,用于將客戶端請(qǐng)求轉(zhuǎn)發(fā)到http://api.example.com,并解決跨域問(wèn)題。
示例代碼:

server {
  listen 80;
  server_name www.example.com;

  location /api {
    add_header 'Access-Control-Allow-Origin' '*';
    add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
    add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';
    proxy_pass http://api.example.com;
  }
}

在上面的配置中,定義了一個(gè)Nginx服務(wù)器,監(jiān)聽(tīng)80端口,并將所有以/api開(kāi)頭的請(qǐng)求轉(zhuǎn)發(fā)到http://api.example.com,同時(shí)設(shè)置了一些響應(yīng)頭信息,從而實(shí)現(xiàn)了跨域訪問(wèn)。

需要注意的是,由于涉及到跨域訪問(wèn),需要設(shè)置響應(yīng)頭的Access-Control-Allow-*字段,以允許跨域訪問(wèn)。此外,還需要設(shè)置Nginx的CORS配置,從而更好地控制跨域訪問(wèn)的安全性。

3.CORS解決跨域問(wèn)題

CORS(Cross-Origin Resource Sharing)是一種跨域資源共享的機(jī)制,可以用于解決跨域問(wèn)題。CORS機(jī)制允許服務(wù)器在響應(yīng)中設(shè)置一個(gè)Access-Control-Allow-Origin頭部,來(lái)指定允許哪些域名訪問(wèn)資源。

具體實(shí)現(xiàn)方法是,在服務(wù)器端向每一個(gè)響應(yīng)添加一個(gè)Access-Control-Allow-Origin頭部,來(lái)指定允許哪些域名訪問(wèn)資源。如果請(qǐng)求的域名與允許訪問(wèn)的域名一致,則請(qǐng)求可以順利完成;否則,瀏覽器會(huì)阻止請(qǐng)求,從而保證安全性。

下面是一個(gè)簡(jiǎn)單的CORS配置示例,用于允許http://www.example.com和https://www.example.com訪問(wèn)資源。

Access-Control-Allow-Origin: http://www.example.com,https://www.example.com
Access-Control-Allow-Methods: GET, POST, OPTIONS
Access-Control-Allow-Headers: Content-Type

在上面的示例中,Access-Control-Allow-Origin頭部指定了允許訪問(wèn)的域名,Access-Control-Allow-Methods頭部指定了允許的HTTP方法,Access-Control-Allow-Headers頭部指定了允許的請(qǐng)求頭信息。需要注意的是,由于涉及到安全性,需要仔細(xì)控制允許訪問(wèn)的域名和請(qǐng)求頭信息,以避免安全漏洞。

需要注意的是,CORS機(jī)制只能用于瀏覽器端,即僅限于XMLHttpRequest和Fetch API這兩種請(qǐng)求。對(duì)于其他類型的請(qǐng)求,比如通過(guò)curl工具發(fā)送的請(qǐng)求,無(wú)法使用CORS機(jī)制來(lái)解決跨域問(wèn)題,需要使用其他方法,比如Nginx反向代理。

4.postMessage解決跨域問(wèn)題

postMessage是一種可以用于解決跨域問(wèn)題的技術(shù),它是HTML5中引入的一種跨文檔消息傳遞機(jī)制。具體實(shí)現(xiàn)方法是,在發(fā)送消息的窗口中調(diào)用postMessage方法,向接收消息的窗口發(fā)送消息,并在接收消息的窗口中監(jiān)聽(tīng)message事件,接收消息并進(jìn)行處理。

下面是一個(gè)簡(jiǎn)單的postMessage示例,在兩個(gè)不同域名的頁(yè)面之間進(jìn)行消息傳遞:

在發(fā)送消息的頁(yè)面中,可以使用以下代碼向接收消息的頁(yè)面發(fā)送消息:

var receiver = window.opener || window.parent;
receiver.postMessage('Hello, world!', 'http://www.example.com');

在接收消息的頁(yè)面中,可以使用以下代碼監(jiān)聽(tīng)message事件,并處理接收到的消息:

window.addEventListener('message', function(event) {
  if (event.origin !== 'http://www.example.com') return;
  console.log('Received message:', event.data);
});

在上面的代碼中,使用addEventListener方法監(jiān)聽(tīng)message事件,在事件處理函數(shù)中判斷消息來(lái)源是否合法,并進(jìn)行處理。

需要注意的是,postMessage技術(shù)可以用于解決跨域問(wèn)題,但也存在一定的安全風(fēng)險(xiǎn)。因?yàn)閜ostMessage方法可以向任意窗口發(fā)送消息,如果接收消息的窗口沒(méi)有進(jìn)行安全控制,可能會(huì)被惡意網(wǎng)站利用,從而造成安全漏洞。因此,在使用postMessage技術(shù)時(shí),需要仔細(xì)考慮安全性問(wèn)題,并進(jìn)行必要的安全控制。

5.WebSocket解決跨域問(wèn)題

WebSocket是一種可以用于解決跨域問(wèn)題的技術(shù),它是HTML5中引入的一種雙向通信協(xié)議。WebSocket協(xié)議使用標(biāo)準(zhǔn)的HTTP端口(80和443),可以通過(guò)HTTP代理服務(wù)器進(jìn)行通信,因此可以用于跨域通信。

下面是一個(gè)簡(jiǎn)單的WebSocket示例,在兩個(gè)不同域名的頁(yè)面之間進(jìn)行通信:

在客戶端頁(yè)面中,可以使用以下代碼建立WebSocket連接:

var socket = new WebSocket('ws://www.example.com/socket');
socket.addEventListener('open', function(event) {
  console.log('WebSocket connected');
  socket.send('Hello, world!');
});
socket.addEventListener('message', function(event) {
  console.log('Received message:', event.data);
});

在服務(wù)端頁(yè)面中,可以使用以下代碼監(jiān)聽(tīng)WebSocket連接,并處理接收到的消息:

var WebSocketServer = require('ws').Server;
var server = new WebSocketServer({ port: 8080 });
server.on('connection', function(socket) {
  console.log('WebSocket connected');
  socket.on('message', function(message) {
    console.log('Received message:', message);
    socket.send('Hello, world!');
  });
});

在上面的代碼中,使用WebSocket對(duì)象的send方法向服務(wù)端發(fā)送消息,并使用addEventListener方法監(jiān)聽(tīng)message事件,在事件處理函數(shù)中處理接收到的消息。

需要注意的是,WebSocket技術(shù)可以用于解決跨域問(wèn)題,但也存在一定的安全風(fēng)險(xiǎn)。因?yàn)閃ebSocket協(xié)議允許任意域名的頁(yè)面建立連接,如果服務(wù)端沒(méi)有進(jìn)行安全控制,可能會(huì)被惡意網(wǎng)站利用,從而造成安全漏洞。因此,在使用WebSocket技術(shù)時(shí),需要仔細(xì)考慮安全性問(wèn)題,并進(jìn)行必要的安全控制。

6.devServer代理跨域

在Webpack中,可以使用devServer配置中的proxy選項(xiàng)進(jìn)行跨域代理。devServer代理跨域可以將請(qǐng)求代理到另一個(gè)服務(wù)器,從而解決跨域問(wèn)題。具體實(shí)現(xiàn)方法是,在Webpack的配置文件中配置devServer選項(xiàng),設(shè)置proxy選項(xiàng),將請(qǐng)求轉(zhuǎn)發(fā)到目標(biāo)服務(wù)器,并在響應(yīng)中添加Access-Control-Allow-Origin頭部,實(shí)現(xiàn)跨域訪問(wèn)。

下面是一個(gè)簡(jiǎn)單的devServer代理跨域示例配置:

devServer: {
  proxy: {
    '/api': {
      target: 'http://www.example.com',
      changeOrigin: true,
      pathRewrite: { '^/api': '' },
      headers: {
        'Access-Control-Allow-Origin': '*'
      }
    }
  }
}

在上面的配置中,定義了一個(gè)代理規(guī)則,將所有以/api開(kāi)頭的請(qǐng)求轉(zhuǎn)發(fā)到http://www.example.com,并設(shè)置了一些選項(xiàng),比如changeOrigin表示是否修改請(qǐng)求頭中的Host字段,pathRewrite表示是否對(duì)請(qǐng)求路徑進(jìn)行重寫,headers表示需要添加到響應(yīng)頭中的頭部信息。

需要注意的是,由于涉及到跨域訪問(wèn),需要設(shè)置響應(yīng)頭的Access-Control-Allow-Origin字段,以允許跨域訪問(wèn)。此外,還需要設(shè)置Nginx的CORS配置,從而更好地控制跨域訪問(wèn)的安全性。

需要注意的是,devServer代理跨域只適用于開(kāi)發(fā)環(huán)境,不適用于生產(chǎn)環(huán)境。在生產(chǎn)環(huán)境中,需要使用其他跨域解決方案,比如Nginx反向代理。

附:iframe實(shí)現(xiàn)跨域

iframe(src){
            //數(shù)組
            if(Array.isArray(src)){
                this.docs.visible = true;
            }else{
                this.docs.visible = false;
                
            }
            this.link  = src
            if(this.docs.visible == false){
                if(this.$refs['ruleIframe'] && this.$refs['ruleIframe'].querySelector('iframe')){
                    this.$refs['ruleIframe'].querySelector('iframe').remove()    //刪除自身
                }
                var iframe = document.createElement('iframe');
                iframe.width = '100%';
                iframe.height = '100%';
                iframe.setAttribute('frameborder','0')
                iframe.src = src;                
                this.append(iframe)
            }
            
        },
        //創(chuàng)建元素 防止  獲取不到 ruleIframe 遞歸
        append(iframe){
            if(this.$refs['ruleIframe']){
                this.$refs['ruleIframe'].appendChild(iframe);
                return
            }
            setTimeout(()=>{
                this.append(iframe);
            },500)    
        },

總結(jié)

到此這篇關(guān)于Vue學(xué)習(xí)筆記之跨域的6種解決方案的文章就介紹到這了,更多相關(guān)Vue跨域解決方案內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue?+?ElementUI表格內(nèi)實(shí)現(xiàn)圖片點(diǎn)擊放大效果的兩種實(shí)現(xiàn)方式

    Vue?+?ElementUI表格內(nèi)實(shí)現(xiàn)圖片點(diǎn)擊放大效果的兩種實(shí)現(xiàn)方式

    這篇文章主要介紹了Vue?+?ElementUI表格內(nèi)實(shí)現(xiàn)圖片點(diǎn)擊放大效果的兩種實(shí)現(xiàn)方式,第一種使用el-popover彈出框來(lái)實(shí)現(xiàn)而第二種使用v-viewer插件實(shí)現(xiàn),需要的朋友可以參考下
    2024-08-08
  • vue+flask實(shí)現(xiàn)視頻合成功能(拖拽上傳)

    vue+flask實(shí)現(xiàn)視頻合成功能(拖拽上傳)

    這篇文章主要介紹了vue+flask實(shí)現(xiàn)視頻合成功能(拖拽上傳),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • Vue.js實(shí)現(xiàn)模擬微信朋友圈開(kāi)發(fā)demo

    Vue.js實(shí)現(xiàn)模擬微信朋友圈開(kāi)發(fā)demo

    本篇文章主要介紹了Vue.js實(shí)現(xiàn)模擬微信朋友圈開(kāi)發(fā)demo,實(shí)現(xiàn)展示朋友圈,評(píng)論,點(diǎn)贊等功能,有興趣的可以了解一下。
    2017-04-04
  • v-for中動(dòng)態(tài)校驗(yàn)el-form表單項(xiàng)的實(shí)踐

    v-for中動(dòng)態(tài)校驗(yàn)el-form表單項(xiàng)的實(shí)踐

    在項(xiàng)目開(kāi)發(fā)中,我們經(jīng)常會(huì)遇到表單保存的功能,本文主要介紹了v-for中動(dòng)態(tài)校驗(yàn)el-form表單項(xiàng)的實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2022-05-05
  • vue中使用swiper5方式

    vue中使用swiper5方式

    這篇文章主要介紹了vue中使用swiper5方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue單頁(yè)緩存存在的問(wèn)題及解決方案(小結(jié))

    vue單頁(yè)緩存存在的問(wèn)題及解決方案(小結(jié))

    這篇文章主要介紹了vue單頁(yè)緩存存在的問(wèn)題及解決方案(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Vue3(二)集成Ant Design Vue

    Vue3(二)集成Ant Design Vue

    上一篇文章我們介紹了利用Vue3 創(chuàng)建Vue CLI 項(xiàng)目(一),接下來(lái)就來(lái)看看Vue3集成Ant Design Vue 的相關(guān)資料,需要的小伙伴可以參考一下文章的具體內(nèi)容
    2021-10-10
  • Vue項(xiàng)目發(fā)布后瀏覽器緩存問(wèn)題解決方案

    Vue項(xiàng)目發(fā)布后瀏覽器緩存問(wèn)題解決方案

    在vue項(xiàng)目開(kāi)發(fā)中一直有一個(gè)令人都疼的問(wèn)題,就是緩存問(wèn)題,這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目發(fā)布后瀏覽器緩存問(wèn)題的解決方案,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • Vue3自定義drag指令詳解

    Vue3自定義drag指令詳解

    這篇文章主要為大家詳細(xì)介紹了Vue3自定義drag指令的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • Vue高效管理組件狀態(tài)的多種方法

    Vue高效管理組件狀態(tài)的多種方法

    在現(xiàn)代前端開(kāi)發(fā)中,隨著應(yīng)用復(fù)雜度的不斷提升,組件狀態(tài)管理成為構(gòu)建高效、可維護(hù)的Vue應(yīng)用的核心問(wèn)題,本文將介紹多種管理組件狀態(tài)的方法,需要的朋友可以參考下
    2025-03-03

最新評(píng)論