写后端springboot项目,前端调用后端接口时,出现跨域配置问题

写后端springboot项目,前端调用后端接口时,出现跨域配置问题

1. 问题

在前端vue项目调用后台已写好的接口:“http://localhost:8888/user/list”,发现前端页面调用此接口时,会出现报错,在Postman调用测试时不会报错

在这里插入图片描述

根据接口报错情况,明显是出现跨域问题,需要在后端配置

2. 解决

重写WebMvcConfigurer类进行全局配置,复制以下代码:

在这里插入图片描述

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)
            // 放行哪些原始域
            .allowedOrigins("*")
            // 放行哪些请求方式
            .allowedMethods("GET", "POST", "PUT", "DELETE")
            // 放行哪些原始请求头部信息
            .allowedHeaders("*")
            // 暴露哪些头部信息
            .exposedHeaders("*");
    }
}
但配置后,运行启动后端,出现报错:

在这里插入图片描述

根据报错提示,需要将刚刚配置的代码:allowedOrigins修改成allowedOriginPatterns

在这里插入图片描述

修改后重启服务,前端页面能正常调用接口,跨域问题解决

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值