在Spring Cloud Gateway中,跨域问题通常是由于浏览器的同源策略导致的,它阻止了来自不同源(域名、协议或端口)的Web页面请求访问另一个源的资源。Spring Cloud Gateway提供了一个全局过滤器来解决跨域问题。
解决方案:
- 添加全局跨域过滤器:
 
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
    return builder.routes()
            .route("cross-origin", r -> r.order(0)
                    .filter(exposeHeadersGatewayFilterFactory.apply(HttpHeaders.ACCESS_CONTROL_ALLOW_ORIGIN))
                    .uri("http://localhost:8080/")
                    .id("cross_origin_route")
            )
            .build();
}- 配置跨域过滤器:
 
spring:
  cloud:
    gateway:
      globalcors:
        add-to-simple-url-handler-mapping: true
        corsConfigurations:
          '[/**]':
            allowedOrigins: "*"
            allowedMethods:
            - GET
            - POST
            - DELETE
            - PUT
            - OPTIONS在上述配置中,add-to-simple-url-handler-mapping 属性设置为 true 表示启用简单URL的处理映射,allowedOrigins 属性设置为 "*" 表示允许所有域进行跨域请求。
注意:在生产环境中,应该将 allowedOrigins 设置为特定的域,以保证安全。
