SpringCloud zuul 网关如何解决跨域问题

时间:2022-07-01 00:24:41

跨域

在SpringCloud中 zuul 和springboot 要同时配置才能实现网关处理跨域

解决Access to XMLHttpRequest at ‘http://192.168.2.173:8001/energy-base/groupType/getPageByType?timestamp=1557886425725' from origin ‘http://localhost:3000' has been blocked by CORS policy: The ‘Access-Control-Allow-Origin' header contains multiple values ‘http://localhost:3000, *', but only one is allowed.

Access-Control-Allow-Origin只能有一个值解决方案

SpringBoot代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@Configuration
public class CorsConfig {
    @Bean
    public CorsFilter corsFilter() {
        final UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        final CorsConfiguration config = new CorsConfiguration();
        config.setAllowCredentials(true); // 允许cookies跨域
        config.addAllowedOrigin("*");// #允许向该服务器提交请求的URI,*表示全部允许,在SpringMVC中,如果设成*,会自动转成当前请求头中的Origin
        config.addAllowedHeader("*");// #允许访问的头信息,*表示全部
        config.setMaxAge(7200L);// 预检请求的缓存时间(秒),即在这个时间段里,对于相同的跨域请求不会再预检了
        config.addAllowedMethod("*");// 允许提交请求的方法,*表示全部允许
        source.registerCorsConfiguration("/**", config);
        return new CorsFilter(source);
    }
}

zuul yml配置

?
1
2
3
4
5
6
7
8
9
10
zuul:
  #需要忽略的头部信息,不在传播到其他服务
  sensitive-headers: Access-Control-Allow-Origin
  ignored-headers: Access-Control-Allow-Origin,H-APP-Id,Token,APPToken
  max:
    host:
      connections: 5000 #最大请求时间
  host:  #等待
    socket-timeout-millis: 60000
    connect-timeout-millis: 60000

用SpringCloud zuul中遇到的坑

最近笔者在研究和使用SpringCloud Zuul作为微服务的网关。在这个微服务网关,我们集成了权限管理和路由转发到后端,后端的微服务有用SpringBoot开发的,也有用Python Django 开发的。

但是有的服务的调用会出返回下面的消息

{"timestamp":"2020-09-07 11:45:38","status":500,
"error":"Internal Server Error","exception":"com.netflix.zuul.exception.ZuulException",
"message":"GENERAL"
}

上面的错误信息不是每次都必现的,而且不是每个后端API都会出现的;

对于那些返回时间比较长的服务才出现的。

第一反应是修改熔断器的连接时间和读取超时时间。

?
1
2
ribbon.ConnectTimeout=60000
ribbon.ReadTimeout=60000

而且笔者的所有的配置都是对的,但是结果还是不生效。接着笔者又把SpringCloud Zuul的版本升级到最新版本,还是没有把问题解决。

后面才发现是没有把spring-retry的依赖加入pom.xml 里面来,所以配置的retry的参数都不生效,而且日志也不提示缺少了spring-retry的依赖,个人觉得这块zuul代码需要完善一下,只要填写retry的参数,就要判断是否有spring-retry的依赖。

加上spring-retry的依赖后,问题解决!

?
1
2
3
4
5
6
7
8
<dependency>
    <groupId>org.springframework.retry</groupId>
    <artifactId>spring-retry</artifactId>
</dependency>
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
</dependency>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.****.net/gongyanwolf/article/details/90232305