成都网站建设设计

将想法与焦点和您一起共享

springcloud使用zuul解决微服务的跨域问题

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: www.fhadmin.org
 * @Date: 2019/9/16
 * @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);
    }

}

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


分享名称:springcloud使用zuul解决微服务的跨域问题
网站路径:http://chengdu.cdxwcx.cn/article/ppiisp.html