vite配置代理proxy实现跨域问题

hykeda3年前Vue3892

最近在开发vite+vue项目时,调用接口获取服务器数据时提示接口有跨域问题,解决办法是配置代理:

export default defineConfig({
  //配置代理
  server: {
    proxy: {
      '/api': {
        target: 'https://api.baidu.com',
        ws: true,
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, ''),
      },
    },
  },
});

创建request.ts文件,然后配置好axios调用接口:

import axios from 'axios';
// 配置新建一个 axios 实例
const service = axios.create({
    baseURL: 'http://localhost:8888',
    timeout: 50000,
    headers: { 'Content-Type': 'application/json' },
});

创建一个接口文件xxx.ts,引入request.ts

import request from '/@/utils/request';

export function useApi() {
    return {
        ceshi:()=>{
            return request({
                url: '/api/adminMenu.json',
                method: 'get',
            })
        }
    };
}


在我们调用ceshi这个方法时,我们访问的接口为:http://localhost:8888/api/adminMenu.json,我们做了代理以后会捕捉到路由中的‘/api’如果存在则路由会变成:https://api.baidu.com/adminMenu.json,

这样我们就能访问到真实的接口:https://api.baidu.com/adminMenu.json 中的数据了


注意:代理地址如果是本地地址,尽量不要用https://localhost/adminMenu.json,可以用https://127.0.0.1/adminMenu.json代替

标签: vite代理proxy

相关文章

直接在浏览器中使用 vue3+element-plus中icons的方法

首先引入文件,如果用cdn的方式:<script src="//unpkg.com/@element-plus/icons-vue"></script&...

使用vite打包vue项目生成dist文件夹,部署至nginx除了index.html,其他路径都提示404错误的解决

使用vite打包vue项目生成dist文件夹,部署至nginx除了index.html,其他路径都提示404错误的解决

用vue打包生成dist文件夹,然后在本地nginx部署vue项目时只能访问默认页面,刷新和跳转页面都会出问题。原因:只访问了dist文件下的 index.html、index.htm页面,...

uni-app中使用iconfont字体,亲测有用

一、下载好iconfont文件,复制iconfont.ttf这个文件至项目。 在你的项目中创建一个iconfont.css文件,文件内容: @font-face { font-fam...

在写css时不起作用,请排查是否是scoped的问题

在写css的时候,用了框架自带的组件table和card,把table包在了card里面,然后发现table的分页样式出现了问题,查看源码后发现card中写了ul li { margin-left:2...

前端常用的UI组件库

Arco DesignTaro UISemi DesignAnt DesignElementView DesignVantLayui-vueFusion Design1. Arco Desi...

pinia中数据解构

在vuex中获取state中的数据可以解构的方式如下:import { mapState,mapMutations } from "vuex...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。