在 vite 中使用代理会将我重定向到本地主机上的代理 URL,但我特别想将其仅用于后端 API 调用。
P粉412533525
P粉412533525 2024-03-25 20:11:37
0
1
484

这是我的 vite.config.ts:

import { defineConfig } from 'vitest/config'
import vue from '@vitejs/plugin-vue'
import { quasar, transformAssetUrls } from '@quasar/vite-plugin'

const path = require('path');

// https://vitejs.dev/config/
export default defineConfig({
  test: {
    globals: true
  },
  plugins: [
    vue({
      template: {
        transformAssetUrls
      }
    }),
    quasar({
      sassVariables: 'src/assets/scss/quasar-variables.sass'
    })
  ],
  resolve: {
    alias: {
      "@": path.resolve(__dirname, './src'),
    },
  },
  server: {
    proxy: {
      '/socket': {
        target: 'wss://abc-website.com:4221/',
        changeOrigin: true,
        ws: true,
        rewrite: (path) => path.replace('^/socket', ''),
      },
      '/streaming/': {
        target: 'https://abc-website.com/',
        changeOrigin: true,
      },
      '/': {
        target: 'https://abc-website.com/',
        changeOrigin: true,
        secure: false,
        ws: true
      },
    }
  }
})

每当加载我的应用程序时,它都会在我的 locahost 端口上访问 https://abc-website.com。

我只想将上面的网址用于后端 api 调用,例如 https://abc-webite.com/api/auth。

此外,在 vite.config.ts 中设置代理后,我将 baseURL 设置为“api/”。

此外,在稍作更改后,它会调用 REST api,例如 https://localhost:3000/auth,我应该是 https://locahost:3000/api/auth

Vite 代理似乎对我来说无法正常工作。

P粉412533525
P粉412533525

全部回复(1)
P粉426780515

我认为你可以这样做:

server: {
  proxy: {
    // ... your other proxies
    '/api': {
      target: 'https://abc-website.com/',
      changeOrigin: true,
      secure: false,
      ws: true,
      rewrite: (path) => path.replace(/^\/app/, ''),
    },
  }
}

然后,您对 localhost:3000/api/my-endpoint 等网站的所有请求都应代理到 https://abc-website.com/my-endpoint 。您无法代理所有“基本”请求,因为它们被保留用于服务其他所有内容、所有资产、index.html 等,但我也很友善

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!