@Configuration public class CorsConfig { @Bean public CorsFilter corsFilter() { UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); CorsConfiguration config = new CorsConfiguration(); config.addAllowedOrigin("*"); config.addAllowedHeader("*"); config.addAllowedMethod("*"); config.setMaxAge(3600L); source.registerCorsConfiguration("/**", config); return new CorsFilter(source); } }
时间: 2024-04-05 17:31:46 浏览: 126
这是一个 Java Spring Boot 的配置类,用于设置跨域资源共享 (CORS)。它创建了一个名为 CorsFilter 的 Bean,该 Bean 通过 UrlBasedCorsConfigurationSource 和 CorsConfiguration 对跨域资源共享进行配置。其中,addAllowedOrigin("*") 允许所有来源的请求访问,addAllowedHeader("*") 允许所有请求头访问,addAllowedMethod("*") 允许所有 HTTP 方法访问,setMaxAge(3600L) 设置预检请求的有效期为 1 小时。最后,source.registerCorsConfiguration("/**", config) 将配置应用于所有的请求路径。
相关问题
package com.group9.trainmanager.crossConfig; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.cors.CorsConfiguration; import org.springframework.web.cors.UrlBasedCorsConfigurationSource; import org.springframework.web.filter.CorsFilter; @Configuration public class CorsConfig { // 当前跨域请求最大有效时长。这里默认1天 private static final long MAX_AGE = 24 * 60 * 60; @Bean public CorsFilter corsFilter() { UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedOrigin("*"); // 1 设置访问源地址 corsConfiguration.addAllowedHeader("*"); // 2 设置访问源请求头 corsConfiguration.addAllowedMethod("*"); // 3 设置访问源请求方法 corsConfiguration.setMaxAge(MAX_AGE); source.registerCorsConfiguration("/**", corsConfiguration); // 4 对接口配置跨域设置 return new CorsFilter(source); } }
根据您提供的代码,这是一个用于配置跨域请求的类。在该类中,使用了 `@Configuration` 注解,表示这是一个配置类。
`@Bean` 注解用于将方法返回的对象注册为一个 Bean,并且交给 Spring 管理。
`CorsFilter` 是一个用于处理跨域请求的过滤器,它可以在请求进入控制器之前对请求进行处理。
在方法 `corsFilter()` 中,首先创建了一个 `UrlBasedCorsConfigurationSource` 对象,用于配置跨域请求的源地址。
然后创建了一个 `CorsConfiguration` 对象,并通过 `corsConfiguration.addAllowedOrigin("*")`、`corsConfiguration.addAllowedHeader("*")` 和 `corsConfiguration.addAllowedMethod("*")` 分别设置允许的访问源地址、请求头和请求方法。
接下来,设置了跨域请求的最大有效时长为 1 天。
最后,通过 `source.registerCorsConfiguration("/**", corsConfiguration)` 将跨域配置应用到所有接口上。
通过返回一个经过跨域配置的 `CorsFilter` 对象,将该过滤器注册到 Spring 容器中,以便应用程序能够正确处理跨域请求。
如果您对跨域配置或其他方面有更多疑问,请随时提问!
package com.xiangyixiang.www.cloud.business.gateway.configure; import org.springframework.beans.factory.ObjectProvider; import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; import org.springframework.boot.autoconfigure.http.HttpMessageConverters; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.http.converter.HttpMessageConverter; import org.springframework.web.cors.CorsConfiguration; import org.springframework.web.cors.reactive.CorsWebFilter; import org.springframework.web.cors.reactive.UrlBasedCorsConfigurationSource; import org.springframework.web.util.pattern.PathPatternParser; import java.util.stream.Collectors; /**网关统一配置允许跨域 * zj 解决跨域问题 * @author 张静 */ @Configuration public class CorsConfig { @Bean public CorsWebFilter corsFilter() { CorsConfiguration config = new CorsConfiguration(); config.setAllowCredentials(true); config.addAllowedMethod("*"); config.addAllowedOrigin("http://39.105.36.172:9250"); config.addAllowedHeader("*"); UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser()); source.registerCorsConfiguration("/**", config); return new CorsWebFilter(source); } @Bean @ConditionalOnMissingBean public HttpMessageConverters messageConverters(ObjectProvider<HttpMessageConverter<?>> converters) { return new HttpMessageConverters(converters.orderedStream().collect(Collectors.toList())); } }
这段代码是一个 Spring Boot 网关配置,用于解决跨域问题。它创建了一个 `CorsWebFilter`,并配置了允许跨域请求的规则。
具体来说,它做了以下几件事情:
1. 创建一个 `CorsConfiguration` 对象,并配置允许跨域请求的规则,包括允许的方法、来源、头信息等。
2. 创建一个 `UrlBasedCorsConfigurationSource` 对象,并将 `CorsConfiguration` 配置对象注册到该对象上。
3. 创建一个 `CorsWebFilter` 对象,并将 `UrlBasedCorsConfigurationSource` 对象传递给它,以创建一个过滤器链,用于拦截跨域请求。
4. 创建一个 `HttpMessageConverters` 对象,并配置在没有其他相应的 bean 的情况下使用它。
这个配置类是使用 Java 代码的方式来实现的,它可以替代 Spring Boot 的默认配置。它的作用是在 Spring Boot 应用程序中启用跨域请求,并允许来自 `http://39.105.36.172:9250` 的请求访问。如果你想允许其他来源的请求访问,可以修改 `config.addAllowedOrigin` 属性的值。
请注意,这个配置类只是一个示例代码,具体要根据你的需求来修改。如果你的应用程序使用的是 Spring Cloud Gateway,也可以使用 Gateway 提供的跨域配置方式来解决跨域问题。
阅读全文