springcloud zuul 跨域問題

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

相關文章
相關標籤/搜索