跨域问题的解决方案和实现原理

跨域问题的解决方案和实现原理

浏览器本身的特点:

http:80

https:443

ftp:21

跨域问题的产生及其价值意义

JSONP跨域解决方案的底层原理

客户端

script请求资源文件是get请求,不存在域的限制
在这里插入图片描述
后台
在这里插入图片描述
将请求的路径放在script中的src中,路径中的?号后面是一个回调函数 比如http://api.qq.com/list?callback=func 客户端写一个函数叫做func(data) , 服务器接收到了请求后,准备要发送的数据,放在data中,然后拼接成这样的数据结果:“func({….})”传给客户端,客户端拿到“func({….})” 后,取出括号中的数据进行操作。

GET 的缺点:

  • 不安全
  • 有缓存
  • 大小限制

基于iframe的跨域解决方案

  • window.name
  • document.domin
  • location.hash
  • post message

CORS跨域资源共享

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

基于http proxy实现跨域请求

Nginx反向代理

之前会用到JSONP 但是JSONP只能get请求,get请求又不安全,后来会用post method来做,也用iframe来做,但多多少少会有不好的一点,iframe结合的那些方式有域的限制,必须是主域相同,子域不一样,也不是很方便,后来学习,发现CORS和proxy很方便

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值