1.配置zuul
注意zuul要容许与进行跨域相关的头信息java
zuul: #须要忽略的头部信息,不在传播到其余服务 sensitive-headers: Access-Control-Allow-Origin ignored-headers: Access-Control-Allow-Origin,H-APP-Id,Token,APPToken
2.注入CorsFilterreact
package com.cfh.practice.zuulserver.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.cors.CorsConfiguration; import org.springframework.web.cors.reactive.UrlBasedCorsConfigurationSource; /** * @Author: fh www.1b23.com * @Date: 2019/9/24 20:36 * @Description: 使用zuul解决请求跨域问题 */ @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(18000L);// 预检请求的缓存时间(秒),即在这个时间段里,对于相同的跨域请求不会再预检了 config.addAllowedMethod("*");// 容许提交请求的方法,*表示所有容许 source.registerCorsConfiguration("/**", config); return new CorsFilter(source); } }
这样咱们就完成了跨域,但须要注意若是在最外层的服务网关配置了跨域,那服务自身就不能再进行跨域处理不然会引起冲突web