热门IT资讯网

zuul 跨域 springcloud

发表于:2024-11-30 作者:热门IT资讯网编辑
编辑最后更新 2024年11月30日,1.配置zuul注意zuul要允许与进行跨域相关的头信息zuul:#需要忽略的头部信息,不在传播到其他服务 sensitive-headers: Access-Control-Allow-Origi

1.配置zuul
注意zuul要允许与进行跨域相关的头信息

zuul:#需要忽略的头部信息,不在传播到其他服务  sensitive-headers: Access-Control-Allow-Origin  ignored-headers: Access-Control-Allow-Origin,H-APP-Id,Token,APPToken

2.注入CorsFilter

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解决请求跨域问题 */@Configurationpublic 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);    }}

这样我们就完成了跨域,但需要注意如果在最外层的服务网关配置了跨域,那服务自身就不能再进行跨域处理否则会引发冲突


0