普通SpringMVC解决跨域
package com.ebook.auth.config;
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;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import java.time.Duration;
@Configuration
public class CorsConfig implements WebMvcConfigurer {
public CorsConfiguration buildConfig(){
CorsConfiguration config = new CorsConfiguration();
config.addAllowedOrigin("*"); //允许任何域名
config.addAllowedHeader("*"); //允许任何头
config.addAllowedMethod("*"); //允许任何方法
config.addAllowedOrigin("*");
config.setMaxAge(Duration.ofDays(30)); //设置30天之内不在发送OPTIONS预请求
return config;
}
@Bean
public CorsFilter corsFilter() {
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
source.registerCorsConfiguration("/**", buildConfig());
return new CorsFilter(source);
}
}
SpringSecurity
除了加上SpringMVC的方式外,还要在SpringSecurity的配置类上加一句
http.cors().and().csrf().disable();
这篇博客介绍了如何在Spring MVC中配置CORS过滤器以解决跨域问题,包括允许任何域名、头和方法,并设置预请求缓存时间为30天。同时,也提到了在Spring Security配置中启用CORS并禁用CSRF,以确保全面解决跨域访问的安全问题。
1209

被折叠的 条评论
为什么被折叠?



