SpringBoot之CORS跨域请求

什么是跨域

    CORS是一个W3C标准,全称是"跨域资源共享”(Cross-origin resource sharing),允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制。
    它通过服务器增加一个特殊的Header[Access-Control-Allow-Origin]来告诉客户端跨域的限制,如果浏览器支持CORS、并且判断Origin通过的话,就会允许XMLHttpRequest发起跨域请求。

SpringBoot使用CORS解决跨域方法

1、使用@Crossorigin
    可以在支持跨域的方法上或者是Controller上加上@Crossorigin注解
2、使用WebMvcConfigurer的addCorsMappings()方法

@Configuration
public class CorsConfig imp1ements WebMvcConfigurer {
	@Override
	public void addCorsMappings(CorsRegistry registry) {
		//设置允许跨域的路径
		registry.addMapping(" /**")
				//设置允许跨域请求的域名,可以用*表示允许任何域名使用
				.allowedOriginPatterns("*")
				//在Springboot2.4对应Spring5.3后在设置allowCredentials(true)的基础上不能直接使用通配符设置allowedOrigins
				//而是需要指定特定的URL。如果需要设置通配符,需要通过allowedOriginPatterns指定
				.allowedOrigins("*")
				//是否允许cookie
				.allowCredentials(true)
				//设置允许的请求方式
				.allowedMethods("GET", "POST", "DELETE", "PUT")
				//设置允许的header属性
				.allowedHeaders("*")
				//跨域允许时间,表明在3600秒内,不需要再发送预检验请求,可以缓存该结果
				.maxAge(3600);
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值