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

webpack proxy如何解決跨域問題

 更新時間:2023年10月24日 15:46:13   作者:囂張農(nóng)民  
webpack proxy,即webpack提供的代理服務(wù),基本行為就是接收客戶端發(fā)送的請求后轉(zhuǎn)發(fā)給其他服務(wù)器,本文給大家介紹了webpack proxy如何解決跨域問題,感興趣的朋友跟隨小編一起看看吧

webpack proxy如何解決跨域?

一、是什么

webpack proxy,即webpack提供的代理服務(wù)

基本行為就是接收客戶端發(fā)送的請求后轉(zhuǎn)發(fā)給其他服務(wù)器

其目的是為了便于開發(fā)者在開發(fā)模式下解決跨域問題(瀏覽器安全策略限制)

想要實現(xiàn)代理首先需要一個中間服務(wù)器,webpack中提供服務(wù)器的工具為webpack-dev-server

webpack-dev-server

webpack-dev-server是 webpack 官方推出的一款開發(fā)工具,將自動編譯和自動刷新瀏覽器等一系列對開發(fā)友好的功能全部集成在了一起

目的是為了提高開發(fā)者日常的開發(fā)效率,只適用在開發(fā)階段

關(guān)于配置方面,在webpack配置對象屬性中通過devServer屬性提供,如下:

// ./webpack.config.js
const path = require('path')

module.exports = {
    // ...
    devServer: {
        contentBase: path.join(__dirname, 'dist'),
        compress: true,
        port: 9000,
        proxy: {
            '/api': {
                target: 'https://api.github.com'
            }
        }
        // ...
    }
}

devServetr里面proxy則是關(guān)于代理的配置,該屬性為對象的形式,對象中每一個屬性就是一個代理的規(guī)則匹配

屬性的名稱是需要被代理的請求路徑前綴,一般為了辨別都會設(shè)置前綴為 /api,值為對應(yīng)的代理匹配規(guī)則,對應(yīng)如下:

  • target:表示的是代理到的目標地址
  • pathRewrite:默認情況下,我們的 /api-hy 也會被寫入到URL中,如果希望刪除,可以使用pathRewrite
  • secure:默認情況下不接收轉(zhuǎn)發(fā)到https的服務(wù)器上,如果希望支持,可以設(shè)置為false
  • changeOrigin:它表示是否更新代理后請求的 headers 中host地址

二、工作原理

proxy工作原理實質(zhì)上是利用http-proxy-middleware 這個http代理中間件,實現(xiàn)請求轉(zhuǎn)發(fā)給其他服務(wù)器

舉個例子:

在開發(fā)階段,本地地址為http://localhost:3000,該瀏覽器發(fā)送一個前綴帶有/api標識的請求到服務(wù)端獲取數(shù)據(jù),但響應(yīng)這個請求的服務(wù)器只是將請求轉(zhuǎn)發(fā)到另一臺服務(wù)器中

const express = require('express');
const proxy = require('http-proxy-middleware');

const app = express();

app.use('/api', proxy({target: 'http://www.example.org', changeOrigin: true}));
app.listen(3000);

// http://localhost:3000/api/foo/bar -> http://www.example.org/api/foo/bar

三、跨域

在開發(fā)階段, webpack-dev-server 會啟動一個本地開發(fā)服務(wù)器,所以我們的應(yīng)用在開發(fā)階段是獨立運行在 localhost 的一個端口上,而后端服務(wù)又是運行在另外一個地址上

所以在開發(fā)階段中,由于瀏覽器同源策略的原因,當本地訪問后端就會出現(xiàn)跨域請求的問題

通過設(shè)置webpack proxy實現(xiàn)代理請求后,相當于瀏覽器與服務(wù)端中添加一個代理者

當本地發(fā)送請求的時候,代理服務(wù)器響應(yīng)該請求,并將請求轉(zhuǎn)發(fā)到目標服務(wù)器,目標服務(wù)器響應(yīng)數(shù)據(jù)后再將數(shù)據(jù)返回給代理服務(wù)器,最終再由代理服務(wù)器將數(shù)據(jù)響應(yīng)給本地

在代理服務(wù)器傳遞數(shù)據(jù)給本地瀏覽器的過程中,兩者同源,并不存在跨域行為,這時候瀏覽器就能正常接收數(shù)據(jù)

注意:服務(wù)器與服務(wù)器之間請求數(shù)據(jù)并不會存在跨域行為,跨域行為是瀏覽器安全策略限制

參考文獻

https://webpack.docschina.org/configuration/dev-server/#devserverproxy

使用webpack的proxy來解決跨域

使用webpack的proxy來解決跨域問題

什么是跨域

出于瀏覽器的同源策略限制。同源策略(Sameoriginpolicy)是一種約定,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,則瀏覽器的正常功能可能都會受到影響??梢哉fWeb是構(gòu)建在同源策略基礎(chǔ)之上的,瀏覽器只是針對同源策略的一種實現(xiàn)。同源策略會阻止一個域的。javascript腳本和另外一個域的內(nèi)容進行交互。所謂同源(即指在同一個域)就是兩個頁面具有相同的協(xié)議(protocol),主機(host)和端口號(port)

解決思路

使用前端服務(wù)IP和端口來訪問后端接口地址,然后通過webpack的代理,訪問實際的接口地址。就是遵守瀏覽器的游戲規(guī)則。

注意點:

axios的base_url一定是自己本地的,可以不寫,默認就是當前服務(wù)地址。

target是后端的接口地址,也就是說我們在vue.confjg.js里面的taget寫的是實際的請求地址。

可以使用webpack_proxy來解決跨域(主要說的是這里)

vue.config.js

const {defineConfig} = require('@vue/cli-service')
module.exports = defineConfig({
    transpileDependencies: true,
    devServer: {
        proxy: {
            "/api": {
                target: process.env.VUE_APP_BASE_URL, // todo 請注意,這里是后端的地址,這里不是本地的!?。。?
                ws: false, // websocket
                secure: false, // 是否支持https
                changeOrigin: true, // 是否跨域
            }
        }
    }
})


.env.development

env="development"
VUE_APP_BASE_URL = "http://localhost:8000"

Api.ts

/*
@description:
@auther: alex
@data: 12/23/22
*/
import axios, {AxiosResponse} from "axios";

// const instance = axios({
//     method: "post",
//     baseURL: "", // 因為要啟用代理,所以所以這里可以不用寫,默認為當前服務(wù)的IP和端口
//     timeout: 10000,
// })

const instance = axios.create({
    method: "post",
    baseURL: "",
    timeout: 10000,
})
export const post = (url: string, params: any): Promise<AxiosResponse> => {
    return instance.post(url, params)
}

export const get = (url: string, params: any): Promise<AxiosResponse> => {
    return instance.get(url, params)
}


到此這篇關(guān)于webpack proxy如何解決跨域?的文章就介紹到這了,更多相關(guān)webpack proxy解決跨域內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Emberjs 通過 axios 下載文件的方法

    Emberjs 通過 axios 下載文件的方法

    這篇文章主要介紹了Emberjs 通過 axios 下載文件的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • Bootstrap插件全集

    Bootstrap插件全集

    這篇文章主要為大家詳細介紹了Bootstrap插件,包括Bootstrap過渡效果插件、Bootstrap下拉菜單插件等,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 跟我學Nodejs(三)--- Node.js模塊

    跟我學Nodejs(三)--- Node.js模塊

    這是本系列的第三篇文章了,前面2篇網(wǎng)友們反饋回來不少的消息,加上最近2天比較忙,一直沒來得及整理,周末了,趕緊給大家整理下發(fā)出來,本文講的是node.js模塊
    2014-05-05
  • JS+HTML5實現(xiàn)的前端購物車功能插件實例【附demo源碼下載】

    JS+HTML5實現(xiàn)的前端購物車功能插件實例【附demo源碼下載】

    這篇文章主要介紹了JS+HTML5實現(xiàn)的前端購物車功能插件,結(jié)合完整實例形式分析了JS結(jié)合HTML5的storage特性存儲數(shù)據(jù)實現(xiàn)購物車功能的相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下
    2016-10-10
  • 原生js滑動輪播封裝

    原生js滑動輪播封裝

    這篇文章主要為大家詳細介紹了原生js滑動輪播封裝,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • JS實現(xiàn)slide文字框縮放伸展效果代碼

    JS實現(xiàn)slide文字框縮放伸展效果代碼

    這篇文章主要介紹了JS實現(xiàn)slide文字框縮放伸展效果代碼,涉及JavaScript響應(yīng)鼠標事件動態(tài)操作頁面元素屬性的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • 微信小程序?qū)崿F(xiàn)錄音播放錄音功能

    微信小程序?qū)崿F(xiàn)錄音播放錄音功能

    在微信小程序中,實現(xiàn)錄音及播放功能需用到錄音管理器wx.getRecorderManager()和innerAudioContext對象,調(diào)用play方法播放,結(jié)合表單,可以添加錄音和播放按鈕,用數(shù)據(jù)綁定保存路徑,注意上傳服務(wù)器保存錄音文件以便持久化存儲
    2024-10-10
  • Worker加載JS腳本跨域問題的幾種解決方法

    Worker加載JS腳本跨域問題的幾種解決方法

    Web Worker 是一種在后臺線程中運行的 JavaScript 腳本,允許我們在不阻塞主線程的情況下執(zhí)行復(fù)雜計算或處理,Worker 加載的 JS 腳本如果存在跨域問題,可能導(dǎo)致腳本無法正常加載和執(zhí)行,以下是解決 Worker 加載 JS 腳本跨域問題的幾種方法,需要的朋友可以參考下
    2025-02-02
  • js實現(xiàn)橫向拖拽導(dǎo)航條功能

    js實現(xiàn)橫向拖拽導(dǎo)航條功能

    本文主要介紹了js實現(xiàn)橫向拖拽導(dǎo)航條功能的方法。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • 微信小程序canvas截取任意形狀的實現(xiàn)代碼

    微信小程序canvas截取任意形狀的實現(xiàn)代碼

    這篇文章主要介紹了微信小程序canvas截取任意形狀的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01

最新評論