总结前端跨域的拦截流程

前端跨域

跨域的来源是同源策略,为什么要有同源策略也是为了安全着想,防止遭受一些网络攻击,比如:csrf(跨站请求伪造)等,这里不作过多解释。

一句话总结:跨域的拦截不是浏览器在请求前拒绝访问不同源URL而是在请求非同源URL后拒绝加载数据!!!

拦截流程

  • 请求允许跨域的访问的url
    • 响应头带有"Access-Control-Allow-Origin","*",告知浏览器可以跨域访问
    • 浏览器收到response信息,并且检查到响应头中有"Access-Control-Allow-Origin", “*”,因此将数据展示出来
  • 请求不允许跨域的访问的url
    • 响应头不带有"Access-Control-Allow-Origin","*",没有表示能够跨域访问的请求头信息,所以浏览器不可以跨域访问
    • 页面收到了信息,但是没有检查到响应头中有允许跨域访问的设置,因此没有对数据进行加载渲染。并且报出下面的异常:
      No 'Access-Control-Allow-Origin' header ispresent on the requested resource

总结: 没有设置允许跨域访问,但是依然请求到了数据。这说明跨域访问的限制并不是浏览器限制发送请求,而是浏览器阻止了请求后数据的加载渲染

流程总概:

  • 浏览器发送跨域请求
  • 接收response数据
    • 看看响应头是否带有"Access-Control-Allow-Origin","*"这类允许跨域的字样
  • 检查响应头
    • 如果响应头中没有允许跨域访问的配置,则请求到的数据不进行加载,并报出响应异常
    • 如果响应头中有允许跨域访问的设置,正常加载数据
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

努力不熬夜的小喵

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

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

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

打赏作者

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

抵扣说明:

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

余额充值