vite + axios 代理不起作用 404 无效

发布于:2025-02-12 ⋅ 阅读:(39) ⋅ 点赞:(0)

vite + axios 代理不起作用

先看官方示例

在这里插入图片描述

export default defineConfig({
  server: {
    proxy: {
      // 字符串简写写法
      '/foo': 'http://localhost:4567',
      // 选项写法
      '/api': {
        target: 'http://jsonplaceholder.typicode.com',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      },
      // 正则表达式写法
      '^/fallback/.*': {
        target: 'http://jsonplaceholder.typicode.com',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/fallback/, '')
      },
      // 使用 proxy 实例
      '/api': {
        target: 'http://jsonplaceholder.typicode.com',
        changeOrigin: true,
        configure: (proxy, options) => {
          // proxy 是 'http-proxy' 的实例
        }
      },
      // Proxying websockets or socket.io
      '/socket.io': {
        target: 'ws://localhost:3000',
        ws: true
      }
    }
  }
})

这个是地址可以自己看去看

https://vitejs.cn/vite3-cn/config/server-options.html#server-open

我自己的情况

其实很简单
但是我的项目就是不行
一直显示404
这个是浏览器提示
在这里插入图片描述在这里插入图片描述很苦恼怎么改都不行,但是用postman是可以掉通的
在这里插入图片描述

最后解决

不过最后还是解决了,是自己理解错误了

baseUrl

这个地方不要填完整的地址写个名字或者不写都行

错误示例
const http = axios.create({
    baseURL: 'http://127.0.0.1:8888',
    timeout: 1000,
    headers: {'X-Custom-Header': 'foobar'}
});
正确示例
const http = axios.create({
    baseURL: 'jvm',
    timeout: 1000,
    headers: {'X-Custom-Header': 'foobar'}
});
vite.config.js

这个就更简单了,直接复制官方的就行

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vite.dev/config/
export default defineConfig({
  plugins: [vue()],
  server:{
    proxy:{
      '/jvm': {
        target: 'http://127.0.0.1:8888',
        changeOrigin: true,
        rewrite: (path) => {
          return path.replace(/^\/jvm/, '')
        }
      },
    }
  }
})

我实际的地址是 http://127.0.0.1:8888/api/hello
replace 之后就是正确的地址了

这就完了
在这里插入图片描述

是不是超简单

所以有问题多看官方文档,不要老搜索