跨域问题及解决方案

一、跨域

已拦截跨源请求:同源策略禁止读取位于http://locaLhost:8080/user/list 的远程资源。

(原因: CORS 头缺少’Access-Control Allow-Origin’) 。状态码: 200。

1、为什么会出现跨域问题?

出于浏览器的同源策略限制。

http的一个禁止协议,禁止当前网站的js脚本使用跨域资源的协议(防止跨站攻击),但是该禁止协议不作
用于浏览器。除非,http请求中已经加入了允许跨域的协议。

所谓同源(即指在同一个域)就是两个地址具有相同的协议(protocol)、主机(host)和端口号(port)

以下情况都属于跨域:

跨域原因说明示例
二域名不同www.jd.com 与 www.taobao.com
域名相同,端口不同www.jd.com:8080 与 www.jd.com:8081
一级域名不同miaosha.baidu.com 与 miaosha.baidu.cn
协议不同http和https

http和https也属于跨域。

一级二级域名不同则跨域,三四五及一下域名不同不跨域。

如果域名和端口都相同,但是请求路径不同,不属于跨域,如:www.jd.com/item 和 www.jd.com/goods

同源策略会阻止一个域的javascript脚本和另外一个域的内容进行交互。

而我们刚才是从localhost:5500端口去访问localhost:8080端口,这属于端口不同,跨域了。

2、解决跨域问题

  1. Cors,Http允许跨域协议

    Spring早就给我们提供了解决方案,我们只需要在对应controller上添加一个注解就可以了

    我们在 UserController 类上添加跨域标签@CrossOrigin,再进行测试,则测试成功!

    @CrossOrigin //解决跨域问题
    
  2. jsonp,利用js标签的一个漏洞

  3. 利用Ngnix的反向代理

Axios经常使用的拦截器

在前后端分离的系统中,难以避免会出现跨域,在跨域情况下,cookie是不共享的,这样导致后端无法获取前端请求中的cookie,于是就不可避免的要求前端在发送请求时携带一些必要的cookie信息,如token用户凭证或者jsessionid会话id等信息,这就产生了前端拦截器的需求

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

龙龙龙呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值