springboot-vue项目解决跨域问题

springboot 整合 vue 项目时一定会出现跨域问题

解决(前后端一起配置解决)

 

后端

新建一个corsConfig 类,目录结构如图

 

代码如下:(可直接复制使用)

//跨域使用
package com.example.demo.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("/**")
                .allowedOrigins("*")
                .allowedMethods("GET","HEAD","POST","PUT","DELETE","OPTIONS")
                .allowCredentials(true)
                .maxAge(3600)
                .allowedHeaders("*");
    }
}
​
​

前端

在根目录下创建vue.config.js(一般会有两个 config.js)

 

在 vue.config.js 中写入如下代码

​
module.exports = {
    devServer: {
        proxy: {
            '/api': {//表示拦截以/api开头的请求路径
                target: 'http://(这里填你项目真实的后端地址)',
                changOrigin: true,//是否开启跨域
                pathRewrite: {
                    '^/api': '' //重写api,把api变成空字符,因为我们真正请求的路径是没有api的
                }
            }
        }
    }
}
​

​

找到 baseUrl (一般是在base.js)

axios.defaults.baseURL='api'

总结:

这些操作会将原本的项目路径变成 /api/*

所以在后端上 类上看见写上 @RequestMapping("/api") 就是为了解决跨域问题

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值