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

Vue中的反向代理

 更新時間:2023年01月23日 13:03:13   作者:呱呱?.?  
這篇文章主要介紹了Vue中的反向代理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Vue反向代理

config下面的index.js文件

const ios = require('./os');

module.exports = {
? dev: {

? ? // Paths
? ? assetsSubDirectory: 'static',
? ? assetsPublicPath: '/',
? ? proxyTable: {
? ? ? '/api': {
? ? ? ? target: 'http://192.168.0.127:8890', // 跨域地址
? ? ? ? changeOrigin: true, //是否跨域
? ? ? ? secure: false //是否使用https
? ? ? }
? ? },

? ? host: {ip: ios.ip, org: 'linkName.com'}, /*localhost,192.168.0.37*/
? ? port: 2019, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
? ? autoOpenBrowser: true,
? ? errorOverlay: true,
? ? notifyOnErrors: false,
? ? poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-

? ? // Use Eslint Loader?
? ? useEslint: false,
? ? // If true, eslint errors and warnings will also be shown in the error overlay
? ? // in the browser.
? ? showEslintErrorsInOverlay: false,

? ? devtool: '#cheap-source-map', //‘inline-source-map'
? ? cacheBusting: true,
? ? cssSourceMap: false,
? }
}

ios 文件

const interfaces = require('os').networkInterfaces();
let IPAdress = '';
for(let devName in interfaces){
? let iface = interfaces[devName];
? for(let i=0;i<iface.length;i++){
? ? let alias = iface[i];
? ? if(alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal){
? ? ? IPAdress = alias.address;
? ? }
? }
}

module.exports = { ip : IPAdress }

API請求

// 導入axios
import axios from 'axios'
axios.get('/api/v1/home/getIndexInfo').then(function(res){
? ? ? ? ? console.log(res);
});

Vue反向代理相關(guān)概念及配置

反向代理使用場景

在前后端分離開發(fā)的場景,前端有個服務器(提供靜態(tài)頁面),后端有個服務器(提供接口)

此時,前端需要連接后端的接口,就會出現(xiàn)跨域問題

在發(fā)布環(huán)境中,如果存在跨域問題,使用nginx

如果前后端代碼在一個服務器,不存在跨域問題  

跨域的解決方案

  • jsonp(前端解決方案)
  • CORS(后端解決方案):cross origin resource sharing
  • 反向代理(前端解決方案)

什么是反向代理 

反向代理隱藏真實的服務端,讓瀏覽器依然是同源

反向代理原理

通過偽造請求使得http請求為同源的,然后將同源的請求發(fā)送到反向代理服務器上,由反向代理服務器去請求真正的url,這樣就繞過直接請求真正的url導致的跨域問題

反向代理的配置

vue-cli3的反向代理

在項目根目錄下新建vue.config.js文件

配置代碼:

module.exports = {
? lintOnSave:false,
? devServer:{
? ? proxy: {?
? ? ? '/api': {?
? ? ? target: 'http://localhost:80',
? ? ? changeOrigin: true,?
? ? ? pathRewrite: {
? '^/api': "" ??
},
?'/apidouban': {
? ? ? target: 'http://localhost:3001',
? ? ? changeOrigin: true,?
? ? ? pathRewrite: {
? '^/apidouban': ""
}
? ?}
? ? ? }
? ?}
}

反向代理執(zhí)行過程:

axios訪問地址中的 /api 轉(zhuǎn)換為 target + /api:

(eg:http:localhost:9000/api/goods 轉(zhuǎn)換為 http://localhost:80/api/goods)

創(chuàng)建虛擬服務器

去掉/api:

(eg:http://localhost:80/goods)

總結(jié)

頁面axios請求時請求與頁面url一樣的地址,地址后面拼接api,反向代理服務器會將請求地址中/api之前的地址轉(zhuǎn)變?yōu)閠arget中的地址,這樣一來在頁面發(fā)生請求時瀏覽器會認為是同源,不會報錯;

有時候一個頁面服務器可能會請求好幾個后端服務器,這時,反向代理可以設置多個,/api這個名字也是自定義的

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue 2.0在IE11中打開項目頁面空白的問題解決

    Vue 2.0在IE11中打開項目頁面空白的問題解決

    這篇文章主要給大家介紹了關(guān)于Vue 2.0在ie 11中打開項目頁面空白問題的解決方法,文中詳細分析出現(xiàn)該問題的原因,并給出了詳細的解決方法,需要的朋友可以參考借鑒,下面跟著小編來一起學習學習吧。
    2017-07-07
  • vue中組件的3種使用方式詳解

    vue中組件的3種使用方式詳解

    這篇文章主要給大家介紹了關(guān)于vue中組件的3種使用方式,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-03-03
  • 關(guān)于配置babel-plugin-import報錯的坑及解決

    關(guān)于配置babel-plugin-import報錯的坑及解決

    這篇文章主要介紹了關(guān)于配置babel-plugin-import報錯的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue-cli項目修改文件熱重載失效的解決方法

    vue-cli項目修改文件熱重載失效的解決方法

    今天小編就為大家分享一篇vue-cli項目修改文件熱重載失效的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue中watch監(jiān)聽器用法之deep、immediate、flush

    vue中watch監(jiān)聽器用法之deep、immediate、flush

    Vue是可以監(jiān)聽到多層級數(shù)據(jù)改變的,且可以在頁面上做出對應展示,下面這篇文章主要給大家介紹了關(guān)于vue中watch監(jiān)聽器用法之deep、immediate、flush的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • 基于vue框架手寫一個notify插件實現(xiàn)通知功能的方法

    基于vue框架手寫一個notify插件實現(xiàn)通知功能的方法

    這篇文章主要介紹了基于vue框架手寫一個notify插件實現(xiàn)通知功能的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • el-elementUI使用el-date-picker選擇年月

    el-elementUI使用el-date-picker選擇年月

    本文主要介紹了el-elementUI使用el-date-picker選擇年月,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2024-02-02
  • Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化

    Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化

    這篇文章主要介紹了Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • vue+axios+element ui 實現(xiàn)全局loading加載示例

    vue+axios+element ui 實現(xiàn)全局loading加載示例

    今天小編就為大家分享一篇vue+axios+element ui 實現(xiàn)全局loading加載示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue.js 2.0 移動端拍照壓縮圖片預覽及上傳實例

    Vue.js 2.0 移動端拍照壓縮圖片預覽及上傳實例

    這篇文章主要介紹了Vue.js 2.0 移動端拍照壓縮圖片預覽及上傳實例,本來移動端開發(fā)H5應用,準備將mui框架和Vue.js+vue-router+vuex 全家桶結(jié)合起來使用
    2017-04-04

最新評論