溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何處理vue上線跨域問題

發(fā)布時間:2023-04-18 14:34:59 來源:億速云 閱讀:138 作者:iii 欄目:web開發(fā)

這篇“如何處理vue上線跨域問題”文章的知識點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“如何處理vue上線跨域問題”文章吧。

什么是跨域

跨域是指在訪問一個服務(wù)器上的資源時,使用的是跨域請求的方式??缬蛘埱笥泻芏喾N,其中常見的有跨域訪問資源、跨域?qū)慶ookie、跨域調(diào)用接口等。在瀏覽器安全策略之下,跨域請求是默認(rèn)禁止的,因為跨域請求可能帶來安全風(fēng)險。

解決Vue上線跨域問題

1.代理服務(wù)器

代理服務(wù)器是通過在前端請求后臺接口時,將請求轉(zhuǎn)發(fā)到接口所在的服務(wù)器上,在前端代碼中使用代理服務(wù)器的地址作為請求路徑,保證請求正常進(jìn)行。利用代理服務(wù)器,前端能夠?qū)崿F(xiàn)對接口的請求轉(zhuǎn)發(fā),可以對后端接口的返回內(nèi)容進(jìn)行代理,修改返回內(nèi)容,同時能夠在請求前、請求后加一些修改性參數(shù)或處理邏輯。代理服務(wù)器大都是后端人員編寫,前端項目調(diào)用即可。

代理服務(wù)器有很多種,例如Nginx、阿里云API網(wǎng)關(guān)、Apache等等。在Vue項目上線時,使用代理服務(wù)器將所有接口的訪問路徑指向同一個域名,例如將所有接口請求路徑重定向到“/api”,使用“/api”作為請求路徑。然后在代理服務(wù)器上定義一個轉(zhuǎn)發(fā)規(guī)則,將以“/api”開頭的請求轉(zhuǎn)發(fā)到后端接口所在的服務(wù)器上就可以解決跨域問題。

在Vue項目中配置代理服務(wù)器:

//vue.config.js
module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        changeOrigin: true, //是否跨域
        pathRewrite: {
          '^/api': '/'
        }
      },
    }
  }
}

2.jsonp

JSONP是JavaScript和跨域請求的一種解決方案??蛻舳送ㄟ^動態(tài)創(chuàng)建<script>標(biāo)簽,添加需要請求的URL(接口地址)以及回調(diào)函數(shù)作為參數(shù),發(fā)送請求到服務(wù)器。服務(wù)器端接受請求后,返回一個JavaScript腳本,callback函數(shù)并攜帶需要的數(shù)據(jù)。最后客戶端在回調(diào)函數(shù)中對返回的數(shù)據(jù)進(jìn)行處理。JSONP是一種比較靈活的跨域解決方式,但是它只能支持GET請求,并且只能請求純文本格式的數(shù)據(jù)。

在Vue項目中使用JSONP:

this.$jsonp('http://api.jisuapi.com/weather/query', { //jsonp函數(shù)可以使用axios+jsonp的方式實現(xiàn)
    city: '上海',
    appkey: 'your appkey'
  }, (data) => {
    console.log(data)
  })

3.CORS

CORS(跨域資源共享)是跨域請求的一種官方解決方案,它可以讓W(xué)eb應(yīng)用服務(wù)器進(jìn)行跨域訪問控制,從而使瀏覽器安全地完成跨域請求。使用CORS,只需要在后臺的響應(yīng)頭信息中增加Access-Control-Allow-Origin字段,并設(shè)置為'*'或指定的域名即可,然后瀏覽器會根據(jù)響應(yīng)頭信息進(jìn)行處理,從而達(dá)到解決跨域請求的問題。

在后臺增加響應(yīng)頭信息:

//以Java Web服務(wù)為例,增加響應(yīng)頭信息
response.setHeader("Access-Control-Allow-Origin", "*");//允許跨域
  1. WebSocket

WebSocket是一種全雙工通信協(xié)議,在跨域請求中起到了很好的解決作用。WebSocket通過HTTP協(xié)議進(jìn)行握手,創(chuàng)建連接后,數(shù)據(jù)可以在客戶端和服務(wù)器之間進(jìn)行雙向傳輸。

在Vue項目中使用WebSocket:

var ws = new WebSocket('ws://localhost:8080');
ws.onopen = function() {
  ws.send('發(fā)送消息到服務(wù)器');
};
ws.onmessage = function(event) {
  console.log('從服務(wù)器接受到 ', event.data);
}

以上就是關(guān)于“如何處理vue上線跨域問題”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI