本文介绍: 这种方式问题比较多,如果没有生效,需要考虑 是不是有其他组件模块影响跨域,例如(Shiro、Sa-Token等过滤器影响)注解标注在 Controller或者 Mapping

1、注解方式

使用 @CrossOrigin注解标注在 Controller或者 Mapping

@RestController
@CrossOrigin
@RequestMapping("/ctro")
public class Controller{

	@CrossOrigin
	@GetMapping(value = "/test")
	public String test(){
		return "Nihao"}
}

2、实现 WebMvcConfigurer 接口

这种方式问题比较多,如果没有生效,需要考虑 是不是有其他组件模块影响跨域,例如(Shiro、Sa-Token等过滤器影响)

@Configuration
@EnableWebMvc
public class CorsConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
            .allowedOrigins("*") // 允许所有域名访问可以根据需求进行配置
            .allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS") // 允许的请求方法
            .allowedHeaders("*") // 允许的请求
            .allowCredentials(true) // 是否允许发送Cookie
            .maxAge(3600); // 预检请求的有效期,单位秒
    }
}

3、使用 FilterRegistrationBean 过滤器 (推荐)

@Configuration
public class CorsConfig {
	
	@Bean
	public FilterRegistrationBean corsFilter() {
		UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
		CorsConfiguration config = new CorsConfiguration();
		config.setAllowCredentials(true);
		
		// 允许所有域名访问可以根据需求进行配置, 使用setAllowedOrigin会出现IllegalArgumentException
		config.addAllowedOriginPattern("*");
		config.addAllowedHeader("*");
		config.addAllowedMethod("*");
		source.registerCorsConfiguration("/**", config);
		
		// 使用FilterRegistrationBean包装CorsFilter
		
		FilterRegistrationBean bean = new FilterRegistrationBean(new CorsFilter(source));
		
		// 设置Filter的优先级,值越小优先级越高
		bean.setOrder(0);
		return bean;
	}

}


原文地址:https://blog.csdn.net/qq_40739917/article/details/134673273

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_5945.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注