Spring Gateway跨域问题

本文介绍了在使用Spring Gateway时遇到的跨域问题及其解决方法。问题源于服务自身和Gateway都配置了跨域,导致浏览器报错'The 'Access-Control-Allow-Origin' header contains multiple values'。解决方式是删除各服务的跨域配置,统一在Gateway中配置。提供了Gateway的跨域配置类示例,包含两种配置方式。
摘要由CSDN通过智能技术生成

问题场景

Gateway如果是单纯的跨域问题其实很好解决,CSDN上面也有很多文章关于Gateway跨域的。我同样也是按照这些文章来解决跨域问题。但是一测试发现前端各种报错:

// 浏览器console报错1:
The 'Access-Control-Allow-Origin' header contains multiple values 'http://xxxxxx, http://xxxxxx', but only one is allowed.
// 浏览器console报错2:
The 'Access-Control-Allow-Origin' header contains multiple values "*, *", but only one is allowed.

问题原因

最后发现其实按照网上的教程来定义gateway跨域配置是没有问题的,而会出现以上报错的原因是因为我在没使用gateway之前,我在每个服务中都定义了一个跨域配置类,这就导致了服务自身配置了跨域,而gateway又配置了一次跨域,造成重复跨域,就导致了浏览器报The ‘Access-Control-Allow-Origin’ header contains multiple values的错误。所以只需把各个服务自身的跨域配置去掉,然后在gateway中按网上的教程正常配置跨域即可。

以下提供一个gateway的跨域配置类,里面有两种实现的方式供各位小伙伴参考:

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.reactive.CorsWebFilter;
import org.springframework.web.cors.reactive.UrlBasedCorsConfigurationSource;

@Configuration
public class GatewayCorsFilter  {

    @Bean
    public CorsWebFilter corsWebFilter(){
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        // 1、配置跨域
        corsConfiguration.addAllowedHeader("*");
        corsConfiguration.addAllowedMethod("*");
        corsConfiguration.addAllowedOrigin("*");
        corsConfiguration.setAllowCredentials(true);
        // 2、设置哪些路径需要跨域
        source.registerCorsConfiguration("/**",corsConfiguration);

        return new CorsWebFilter(source);
    }

    // 该方法是通过重写WebFilter中的filter方法实现的,但通过测试上面的方法更方便,所以改用上面的方法
//    @Override
//    public Mono<Void> filter(ServerWebExchange ctx, WebFilterChain chain) {
//        ServerHttpRequest request = ctx.getRequest();
//        if (CorsUtils.isCorsRequest(request)) {
//            ServerHttpResponse response = ctx.getResponse();
//            HttpHeaders headers = response.getHeaders();
//            headers.remove(HttpHeaders.ACCESS_CONTROL_ALLOW_ORIGIN);
//            headers.set(HttpHeaders.ACCESS_CONTROL_ALLOW_ORIGIN, "你的VUE前端地址");
//            headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_CREDENTIALS, "true");
//            headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_HEADERS, "Content-Type,Accept,Accept-Language,Content-Language");
//            if (request.getMethod() == HttpMethod.OPTIONS) {
//                response.setStatusCode(HttpStatus.OK);
//                return Mono.empty();
//            }
//        }
//        return chain.filter(ctx);
//    }
}
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring GatewaySpring Cloud生态系统中的一个重要组件,用于构建微服务网关。在实际应用中,由于微服务的数量和种类可能很多,网关的主要功能就是将各个服务整合起来,并提供统一的入口。然而,在跨域请求方面,Spring Gateway也存在一些问题,需要进行相应的解决。 跨域请求是指在一个域下的前端页面请求另一个域的资源。由于浏览器的同源策略,通常情况下这种请求是不允许的,因此需要进行一些特殊的处理。 在Spring Gateway中,跨域请求可以通过配置路由(Route)来解决。具体来说,可以在Route的配置中添加一个CorsConfiguration对象,用于设置允许跨域的规则。例如,可以设置允许的来源(Allow-Origin)、允许的请求头(Allow-Headers)等。 下面是一个使用了CorsConfiguration的路由配置示例: ``` spring: cloud: gateway: routes: - id: myRoute uri: http://localhost:8080 predicates: - Path=/api/** filters: - RewritePath=/api/(?<path>.*), /$\{path} - name: CorsFilter args: allowedOrigins: http://*.example.com, http://localhost:8080 allowedMethods: GET, POST allowedHeaders: header1, header2, header3 exposedHeaders: header1, header2 maxAge: 3600 ``` 在这个配置示例中,表示通过路由myRoute(对应/api/**路径)请求http://localhost:8080时,允许的来源为http://*.example.com和http://localhost:8080,允许的请求方法为GET和POST,允许的请求头为header1、header2和header3,暴露的响应头为header1和header2,缓存时间为3600秒。 总的来说,在Spring Gateway中解决跨域请求问题需要通过路由配置来设置CorsConfiguration。通过合理设置允许来源、允许方法和允许请求头等参数,可以解决大部分跨域请求问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值