您现在的位置是:首页 >其他 >vite + axios 代理不起作用 404 无效网站首页其他

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

雄鸡三声天下白 2025-03-21 00:01:03
简介vite + axios 代理不起作用 404 无效

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 之后就是正确的地址了

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

是不是超简单

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

风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。