Vue中跨域问题的解决

目录

[1 跨域的概念](#1 跨域的概念)

[2 解决办法](#2 解决办法)

[2.1 修改请求实例的公共前缀](#2.1 修改请求实例的公共前缀)

[2.2 修改vite.config.js文件](#2.2 修改vite.config.js文件)


1 跨域的概念

由于浏览器的同源策略限制,向不同源(不同协议、不同域名、不同端口)发送ajax请求会失败

2 解决办法

原理:使得浏览器向两个端口发送请求和接手请求,变成了浏览器只和前端端口交互,后端与前端交互。

2.1 修改请求实例的公共前缀

假如你有个请求的实例如下:

javascript 复制代码
//其它代码
const baseURL = 'http://localhost:8080';    //公共前缀
const instance = axios.create({baseURL});

现需要将其修改成如下:

javascript 复制代码
//保证和前端的端口号相同为5173
//相当于http://localhost:5173/api
const baseURL = '/api';    
const instance = axios.create({baseURL});

2.2 修改vite.config.js文件

初始化情况如下:

javascript 复制代码
//其它代码
export default defineConfig({
  plugins: [
    vue(),
  ],
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  }
})

现在需要向其中添加内容使其变成:

javascript 复制代码
export default defineConfig({
  plugins: [
    vue(),
  ],
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  },
  server: {
    proxy: {
      //拦截所有包含/api的链接
      '/api': {
        //转换的目标链接将5173转为8080,由前端发送
        target: 'http://localhost:8080',  
        //是否换源,true则转化  
        changeOrigin: true,    
        //使得转换后的链接中的/api变成空字符串
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    }
  }
})
相关推荐
rfidunion12 分钟前
springboot+VUE+部署(12。Nginx和前端配置遇到的问题)
前端·vue.js·spring boot
vx-Biye_Design25 分钟前
servlet家政公司管理系统-计算机毕业设计源码01438
java·vue.js·spring·servlet·tomcat·maven·mybatis
珹洺28 分钟前
Java-servlet(五)手把手教你利用Servlet配置HTML请求与相应
java·运维·服务器·前端·servlet·html·maven
FYKJ_201036 分钟前
springboot大学校园论坛管理系统--附源码42669
java·javascript·spring boot·python·spark·django·php
QQ243919738 分钟前
语言在线考试与学习交流网页平台信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·spring boot·sql·学习·java-ee
范特西.i1 小时前
QT聊天项目(6)
前端
a1117761 小时前
水体渲染系统(html开源)
前端·开源·threejs·水体渲染
程序员小李白2 小时前
CSS 盒子模型
前端·css·html
Zzz不能停2 小时前
单行 / 多行文本显示省略号(CSS 实现)
前端·css
xiaoxue..2 小时前
TailwindCSS:从“样式民工”到“UI乐高大师”的逆袭
前端·css·ui