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

hykeda3年前Vue4127

最近在开发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

相关文章

useRoute,userRouter的用法

 import { useRoute, useRouter } from 'vue-router'; 这里的useRoute是获取传递的变量:const route...

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

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

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

在html5中使用Vue3,并且使用组件形式

有的时候为了使用vue编写一些前端程序,如果直接搭建框架感觉太过庞大了。如何直接在html中使用呢?接下来详细介绍:1)引入Vue,并创建Vue实例在官网上,已经讲得很清楚了,我们可以这样使用&nbs...

关于uni-app 中 使用async + await 将异步请求同步化

这段时间在使用uni-app开发小程序,希望在页面加载时,获取地区数据,然后展示到页面上。一开始写在了onLoad方法上,发现页面加载时,用异步uni.request方法获取数据,当页面加载完后,异步...

vuex存储和本地存储(localstorage、sessionstorage)的区别

1. sessionStorage    sessionStorage 方法针对一个 session 进行数据存储。当用户关闭浏览器窗口后,数据会被删除。   用法: ...

vite+vue3项目中js方法调用

这这里一创建一个axios接口demo为例:首先安装axios,打开官方GitHub:https://github.com/axios/axios或者访问中文网站:https://www.axios-...

发表评论    

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