前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring cloud修复zuul跨域配置异常

spring cloud修复zuul跨域配置异常

作者头像
Cheng_Blog
发布2022-02-25 09:14:06
4100
发布2022-02-25 09:14:06
举报
文章被收录于专栏:Cheng's Blog

跨域就指着协议,域名,端口不一致,出于安全考虑,跨域的资源之间是无法交互的。简单说就是协议不通,域名不通,端口不同都会产生跨域问题。

1. 配置zuul

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

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

2. 注入CorsFilter

代码语言:javascript
复制
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;

/**
 * @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);
    }

}

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

发表时间:2019-09-17

本站文章除注明转载/出处外,皆为作者原创,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-09-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 配置zuul
  • 2. 注入CorsFilter
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档