来自原始“ null”的消息已被CORS策略阻止:对预检请求的响应未通过访问控制检查:所请求的资源上没有“ Access-Control-Allow-Origin”标头。
这是我在AWS EC2实例上以微服务的形式运行Spring API Gateway时不断收到的消息。
我添加了标头和过滤器的所有组合,在本地计算机上都可以正常工作。但是一旦通过docker-compose部署到EC2实例,该错误就会继续显示。
注意:通过传递spring网关微服务直接访问其他微服务可以正常工作。
我尝试过以下方法,无论有无方法,都无法成功
enter code here
cloud.gateway:
globalcors:
corsConfigurations:
'[/**]':
allowed-headers:
- "*"
allowed-origins:
- "*"
allowed-methods:
- "POST, PUT, ORIGINS"
enter code here
@Configuration
public class CorsConfiguration {
private static final String ALLOWED_HEADERS = "x-requested-with, authorization, Content-Type, Authorization, credential, X-XSRF-TOKEN";
private static final String ALLOWED_METHODS = "GET, PUT, POST, DELETE, OPTIONS";
private static final String ALLOWED_ORIGIN = "*";
private static final String MAX_AGE = "3600";
@Bean
public WebFilter corsFilter() {
return (ServerWebExchange ctx, WebFilterChain chain) -> {
ServerHttpRequest request = ctx.getRequest();
if (CorsUtils.isCorsRequest(request)) {
ServerHttpResponse response = ctx.getResponse();
HttpHeaders headers = response.getHeaders();
//headers.add("Access-Control-Allow-Origin", ALLOWED_ORIGIN);
headers.add("Access-Control-Allow-Methods", ALLOWED_METHODS);
headers.add("Access-Control-Max-Age", MAX_AGE);
headers.add("Access-Control-Allow-Headers",ALLOWED_HEADERS);
if (request.getMethod() == HttpMethod.OPTIONS) {
response.setStatusCode(HttpStatus.OK);
return Mono.empty();
}
}
return chain.filter(ctx);
};
}
}
应该将数据成功放入服务中,但是,此错误一直显示
答案 0 :(得分:0)
您的请求必须具有CORS规范。像这样:
@CrossOrigin(origins = "http://localhost:9000")
@GetMapping("/greeting")
public Greeting greeting(@RequestParam(required=false, defaultValue="World") String name) {
// Your code here ...
}
答案 1 :(得分:0)
如下所示添加CORS配置:
CORSConfig.java
@Configuration
public class CORSConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedOrigins("*")
.allowedMethods("GET", "POST", "PUT", "DELETE", "HEAD");
}
}
答案 2 :(得分:0)
我发现问题出在哪里,实际上是在API网关级别以及内部微服务上放置了CORS过滤器的重复。
删除内部的使其工作正常。但是我仍然认为,解决方案还不够成熟。因为有时您需要直接访问内部微服务