欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

一、跨域是什么?

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

二、跨域問題的解決方法

1.JSONP

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

2.Nginx反向代理

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

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;
  }
}

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

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

3.CORS解決跨域問題

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

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

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

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頭部指定了允許訪問的域名,Access-Control-Allow-Methods頭部指定了允許的HTTP方法,Access-Control-Allow-Headers頭部指定了允許的請求頭信息。需要注意的是,由于涉及到安全性,需要仔細控制允許訪問的域名和請求頭信息,以避免安全漏洞。

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

4.postMessage解決跨域問題

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

下面是一個簡單的postMessage示例,在兩個不同域名的頁面之間進行消息傳遞:

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

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

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

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

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

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

5.WebSocket解決跨域問題

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

下面是一個簡單的WebSocket示例,在兩個不同域名的頁面之間進行通信:

在客戶端頁面中,可以使用以下代碼建立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ù)端頁面中,可以使用以下代碼監(jiān)聽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對象的send方法向服務(wù)端發(fā)送消息,并使用addEventListener方法監(jiān)聽message事件,在事件處理函數(shù)中處理接收到的消息。

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

6.devServer代理跨域

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

下面是一個簡單的devServer代理跨域示例配置:

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

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

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

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

附:iframe實現(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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

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

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

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

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

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

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

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

    v-for中動態(tài)校驗el-form表單項的實踐

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

    vue中使用swiper5方式

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

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

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

    Vue3(二)集成Ant Design Vue

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

    Vue項目發(fā)布后瀏覽器緩存問題解決方案

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

    Vue3自定義drag指令詳解

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

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

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

最新評論