Spring Cloud Gateway 网关跨域问题解决
在Spring Cloud Gateway中解决跨域问题,可以通过定义一个全局的过滤器来实现。以下是一个简单的示例代码:
import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.Ordered;
import org.springframework.http.HttpHeaders;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;
@Component
public class CorsGlobalFilter implements GlobalFilter, Ordered {
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
HttpHeaders headers = exchange.getResponse().getHeaders();
headers.set("Access-Control-Allow-Origin", "*"); // 允许所有源
headers.set("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");
headers.set("Access-Control-Allow-Headers", "Content-Type, Authorization");
if (exchange.getRequest().getMethod() == HttpMethod.OPTIONS) {
response.setStatusCode(HttpStatus.OK);
return Mono.empty();
}
return chain.filter(exchange);
}
@Override
public int getOrder() {
// 确保此过滤器在其他过滤器之前运行
return -1;
}
}
这段代码定义了一个全局过滤器CorsGlobalFilter
,它实现了GlobalFilter
接口,并在filter
方法中设置了响应头来允许跨域资源共享。getOrder
方法返回的负数确保了这个过滤器会在请求处理之前运行。在实际部署时,为了安全考虑,建议不要使用*
作为Access-Control-Allow-Origin
的值,而是指定允许的域。
评论已关闭