服务端(后端),前端支持跨域请求

服务端(后端),前端支持跨域请求

几种支持跨域请求的方式 解释的很简单
几种支持跨域请求的方式
在这里插入图片描述
后来发现 nginx转发和解决跨域 更好 具体的解决方案可以搜索nginx解决跨域
核心都是 header增加’Access-Control-Allow-Origin

报错:
Access to XMLHttpRequest at 'localhost:8080/ rom origin ‘null’ has been blocked by CORS policy:

原因:我的前端项目没有支持跨域请求;
解决:
1.前端项目支持跨域请求:如果部署在apache服务器上,要在apache服务器上开启允许跨域请求,我安装教程做了,但是没有成功,大牛们可以自己搜下 apache(或者其他的服务器)开启跨域请求的方法
我是用的XMLRequest发送 的请求,手动在header中加入跨域请求头
在这里插入图片描述
如果成功的标记就是
在这里插入图片描述
请求头header中有这个字段 之后浏览器会自动的测试后端是否支持跨域请求,也就是发一个option方法,如果成功响应,就代表服务器端支持

报错:Response to preflight request doesn’t pass access control check: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.

2.后端支持跨域请求
这个时候报错,就是后端没有支持跨域请求;

1.全局配置支持跨域请求:(如果是有反向代理,可以搜一下nginx配置负载均衡)
我的项目是springBoot项目,大家可以搜一下springBoot支持跨域请求:就是写一个过滤器,在response中手动添加上Access-Control-Allow-Origin ( 这是判断服务端是否支持跨域请求的标志)。

当然也可以手动的在你要支持跨域请求的接口中,在response header中加入Access-Control-Allow-Origin头 ,value为* 这样基本就完成了后端支持跨域请求

3.记录一下坑 (做完2之后,一直还是请求不过)

在这里插入图片描述
可以看到浏览器已经自动的支持跨域请求,options方法就是浏览器自动判断后端是否支持跨域请求,如果有响应就是服务端支持,不成功就如图,证明不支持跨域响应。当时我用postman给我 的接口发GET请求,响应头是有Access-control-allow-origin的,但是浏览器自己生成的请求确没有这个响应头,后来查资料,options为预请求,判断是否支持,而我的代码是@GetMapping ,也就是只有get请求,才会加响应头,options方法根本进不到接口中。
在这里插入图片描述

把@GetMapping 改成@RequestMapping就好了 或者说支持Options方法和接口接受的请求方法。

在这里插入图片描述

最后就完美解决了

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值