如何解决前后端分离出现的跨域问题

1.前端vue3的解决方法

前端通过通过反向代理来解决方法 

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

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],

  server:{
    proxy: { 
      '/api': {
        target: 'http://localhost:8080/',  //你要跨域访问的网址
        changeOrigin: true,   // 允许跨域
        rewrite: (path) => path.replace(/^\/api/, '') // 重写路径把路径变成空字符
      }
    }
  }
})

2.后端的解决方法

配置SpringBoot的跨域

package com.boot.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class CorsConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                //是否发送Cookie
                .allowCredentials(true)
                //放行哪些原始域
                .allowedOriginPatterns("*")
                .allowedMethods("GET", "POST", "PUT", "DELETE")
                .allowedHeaders("*")
                .exposedHeaders("*");
    }
}

注意:在Vue项目中,如果你配置了前端代理(例如使用Vite或Vue CLI的代理设置)来处理跨域请求,后端通常不需要再额外配置CORS(跨源资源共享)头部。这是因为前端代理服务器会将请求转发给后端服务器,并且在转发过程中处理跨域的问题。前端代理实际上充当了一个“中间人”的角色,使得浏览器认为请求是发往同一个源,从而避免了跨域限制。

然而,需要注意的是,前端代理的配置是针对开发环境的,用于在开发过程中避免跨域问题。当应用部署到生产环境时,前端和后端通常会被部署到不同的服务器上,这时就需要后端服务器来配置CORS头部以支持跨域请求。

因此,对于生产环境,即使你在Vue项目中配置了前端代理,后端服务器仍然需要正确配置CORS头部来允许来自不同源的请求。这是因为在生产环境中,请求将直接发送到后端服务器,而不是通过前端代理进行转发。

总结来说,Vue项目中配置的前端代理可以解决开发环境中的跨域问题,但生产环境中仍然需要后端服务器进行CORS配置。

所以如果前端配置了反向代理还出现跨域问题,请把后端配置SpringBoot的跨域给补上

  • 35
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值