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

vue之proxyTable代理超全面配置流程

 更新時間:2022年04月14日 10:11:44   作者:harmsworth2016  
這篇文章主要介紹了vue之proxyTable代理超全面配置流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

前言

用了vue有一年多了,從最初的摸著石頭過河到現在已經能熟練的使用vue開發(fā)項目,學到了許多,特別是vue的代理配置讓我眼前一亮,甚是喜歡,故將自己對proxyTable代理配置整理出來,供致力于的開源的同輩瀏覽,望大家手下留情,哈哈_。

介紹

vue的proxyTable是用于開發(fā)階段配置跨域的工具,可以同時配置多個后臺服務器跨越請求接口,其真正依賴的npm包是http-proxy-middleware,在github上擁有更豐富的配置,按需配置咯。

配置分離

我將代理配置抽離出2個配置文件

在這里插入圖片描述

1. config.dev.js

用于配置后端服務器地址、端口和IP等

2. proxyTableHandler.js

用于添加代理的配置項

config.dev.js如下

/*
* 開發(fā)環(huán)境服務器配置
* @Author: wujiang
* @Date: 2018-08-16 11:32:36
* @Last Modified by: wujiang
* @Last Modified time: 2018-08-18 23:04:34
*/
module.exports = {
   // 開發(fā)環(huán)境代理服務器
   devProxy: {
       host: '0.0.0.0', // ip/localhost都可以訪問
       port: 8080
   },
   // 后端服務器地址
   servers: {
     default: 'http://localhost:8081/springboot-girl',
     jsp: 'http://localhost:8082/springboot-jsp'
   }
}

proxyTableHandler.js如下

/*
 * 開發(fā)環(huán)境代理配置 生產環(huán)境請使用 nginx 配置代理 或 其他方式
 * @Author: wujiang
 * @Date: 2018-08-16 17:16:55
 * @Last Modified by: wujiang
 * @Last Modified time: 2018-08-19 09:18:18
 */
const configDev = require('../config.dev')
module.exports = (() => {
	let proxyApi = {}
    let servers = configDev.servers
    for (let key of Object.keys(servers)) {
        proxyApi[`/${key}`] = {
            // 傳遞給http(s)請求的對象
            target: servers[key],
            // 是否將主機頭的源更改為目標URL
            changeOrigin: true,
            // 是否代理websocket
            ws: true,
            // 是否驗證SSL證書
            secure: false,
            // 重寫set-cookie標頭的域,刪除域名
            cookieDomainRewrite: '',
            // 代理響應事件
            onProxyRes: onProxyRes,
            // 重寫目標的url路徑
            pathRewrite: {
                [`^/${key}`]: ''
            }
        }
    }
    return proxyApi
})()
/**
 * 過濾cookie path,解決同域下不同path,cookie無法訪問問題
 * (實際上不同域的cookie也共享了)
 * @param proxyRes
 * @param req
 * @param res
 */
function onProxyRes (proxyRes, req, res) {
  let cookies = proxyRes.headers['set-cookie']
  // 目標路徑
  let originalUrl = req.originalUrl
  // 代理路徑名
  let proxyName = originalUrl.split('/')[1] || ''
  // 開發(fā)服url
  let server = configDev.servers[proxyName]
  // 后臺工程名
  let projectName = server.substring(server.lastIndexOf('/') + 1)
  // 修改cookie Path
  if (cookies) {
      let newCookie = cookies.map(function (cookie) {
          if (cookie.indexOf(`Path=/${projectName}`) >= 0) {
              cookie = cookie.replace(`Path=/${projectName}`, 'Path=/')
              return cookie.replace(`Path=//`, 'Path=/')
          }
          return cookie
      })
      // 修改cookie path
      delete proxyRes.headers['set-cookie']
      proxyRes.headers['set-cookie'] = newCookie
  }
}

使用方式 config/index.js

const configDev = require('./config.dev')
module.exports = {
	dev: {
    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: proxyTableHandler,
    // Various Dev Server settings
    host: configDev.devProxy.host, // can be overwritten by process.env.HOST
    port: configDev.devProxy.port, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
    autoOpenBrowser: false,
    errorOverlay: true,
    notifyOnErrors: true,
    poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-
    // Use Eslint Loader?
    // If true, your code will be linted during bundling and
    // linting errors and warnings will be shown in the console.
    useEslint: true,
    // If true, eslint errors and warnings will also be shown in the error overlay
    // in the browser.
    showEslintErrorsInOverlay: false,
    /**
     * Source Maps
     */
    // https://webpack.js.org/configuration/devtool/#development
    devtool: 'cheap-module-eval-source-map',
    // If you have problems debugging vue-files in devtools,
    // set this to false - it *may* help
    // https://vue-loader.vuejs.org/en/options.html#cachebusting
    cacheBusting: true,
    cssSourceMap: true
  }
}

效果如下

以/jsp開頭的api

在這里插入圖片描述

以/default開頭的api

在這里插入圖片描述

至此配置代理成功!

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

相關文章

  • vue3 elementPlus 表格實現行列拖拽及列檢索功能(完整代碼)

    vue3 elementPlus 表格實現行列拖拽及列檢索功能(完整代碼)

    本文通過實例代碼給大家介紹vue3 elementPlus 表格實現行列拖拽及列檢索功能,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-10-10
  • vue前端代碼如何通過maven打成jar包運行

    vue前端代碼如何通過maven打成jar包運行

    這篇文章主要介紹了vue前端代碼如何通過maven打成jar包運行問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • vue cli 3.0 搭建項目的圖文教程

    vue cli 3.0 搭建項目的圖文教程

    這篇文章主要介紹了vue cli 3.0 搭建項目的圖文教程,本文通過圖片文字相結合的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue子組件獲取到它父組件數據的4種方法

    vue子組件獲取到它父組件數據的4種方法

    這篇文章主要給大家介紹了關于vue子組件獲取到它父組件數據的4種方法,對于vue來說組件之間的消息傳遞是非常重要的,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • 基于vue、react實現倒計時效果

    基于vue、react實現倒計時效果

    這篇文章主要為大家詳細介紹了基于vue、react實現倒計時效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • vite+vue3+tsx項目打包后動態(tài)路由無法加載頁面的問題及解決

    vite+vue3+tsx項目打包后動態(tài)路由無法加載頁面的問題及解決

    這篇文章主要介紹了vite+vue3+tsx項目打包后動態(tài)路由無法加載頁面的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 利用vue.js把靜態(tài)json綁定bootstrap的table方法

    利用vue.js把靜態(tài)json綁定bootstrap的table方法

    今天小編就為大家分享一篇利用vue.js把靜態(tài)json綁定bootstrap的table方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue+Element UI實現概要小彈窗的全過程

    Vue+Element UI實現概要小彈窗的全過程

    彈窗效果是我們日常開發(fā)中經常遇到的一個功能,下面這篇文章主要給大家介紹了關于Vue+Element UI實現概要小彈窗的相關資料,需要的朋友可以參考下
    2021-05-05
  • 淺談Vue下使用百度地圖的簡易方法

    淺談Vue下使用百度地圖的簡易方法

    本篇文章主要介紹了淺談Vue下使用百度地圖的簡易方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Vue+Canvas繪圖使用的講解

    Vue+Canvas繪圖使用的講解

    這篇文章主要介紹了Vue+Canvas繪圖的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論