位置: 编程技术 - 正文

跨域请求的完美解决方法(JSONP, CORS)(跨域请求的三种方法)

编辑:rootadmin

推荐整理分享跨域请求的完美解决方法(JSONP, CORS)(跨域请求的三种方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:跨域请求的原理,跨域请求方式,跨域请求发出去了吗,跨域请求的解决方案,跨域请求的原理,跨域请求的原理,跨域请求的三种方法,跨域请求的解决方案,内容如对您有帮助,希望把文章链接给更多的朋友!

一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题。解决方法有JSONP,Flash等等。

JSONP

我们发现,Web页面上调用js文件时不受是否跨域的影响,凡是拥有"src"这个属性的标签都拥有跨域的能力,比如<script>、<img>、<iframe>。那就是说如果要跨域访问数据,就服务端只能把数据放在js格式的文件里。恰巧我们知道JSON可以简洁的描述复杂数据,而且JSON还被js原生支持,所以在客户端几乎可以随心所欲的处理这种格式的数据。然后客户端就可以通过与调用脚本一模一样的方式,来调用跨域服务器上动态生成的js格式文件。客户端在对JSON文件调用成功之后,也就获得了自己所需的数据。这就形成了JSONP的基本概念。允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。

jQuery支持JSONP的调用。在另外的一个域名中指定好回调函数名称,就可以用下面的形式来就加载JSON数据。

服务端当然也要提供JSONP的支持,其实只要提供读写callback这个params就可以了。

跨域资源共享(CORS)

Cross-Origin Resource Sharing (CORS) 是W3c工作草案,它定义了在跨域访问资源时浏览器和服务器之间如何通信。CORS背后的基本思想是使用自定义的HTTP头部允许浏览器和服务器相互了解对方,从而决定请求或响应成功与否。

CORS与JSONP相比,更为先进、方便和可靠。

跨域请求的完美解决方法(JSONP, CORS)(跨域请求的三种方法)

1、 JSONP只能实现GET请求,而CORS支持所有类型的HTTP请求。

2、 使用CORS,开发者可以使用普通的XMLHttpRequest发起请求和获得数据,比起JSONP有更好的错误处理。

3、 JSONP主要被老的浏览器支持,它们往往不支持CORS,而绝大多数现代浏览器都已经支持了CORS。

对一个简单的请求,没有自定义头部,要么使用GET,要么使用POST,它的主体是text/plain,请求用一个名叫Orgin的额外的头部发送。Origin头部包含请求页面的头部(协议,域名,端口),这样服务器可以很容易的决定它是否应该提供响应。

服务器端对于CORS的支持,主要就是通过设置Access-Control-Allow-Origin来进行的。

Header set Access-Control-Allow-Origin *

为了防止XSS攻击我们的服务器, 我们可以限制域,比如

Access-Control-Allow-Origin: AWS 支持跨域资源分享功能CORS,向S3上传不需要代理。

以上这篇跨域请求的完美解决方法(JSONP, CORS)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

深入解析JavaScript中的arguments对象 arguments定义所有的函数都有一个自己的arguments对象,用来储存它实际接受到的参数,而不局限于函数声明时所定义的参数列表。它不是数组却类似数组

JavaScript_object基础入门(必看篇) 之前写Java时老是有点蒙,大部分都是用jQuery,但原理还不是很清楚,最近一段时间在系统的学习JavaScript,有什么问题或错误请指出,多谢..................

实例讲解JavaScript中的this指向错误解决方法 看如下对象定义:'usestrict'varjane={name:‘Jane',display:function(){retrun'Personnamed'+this.name;}};这样能正常调用jane.display();下面的调用会出错:varfunc=jane.display;func

标签: 跨域请求的三种方法

本文链接地址:https://www.jiuchutong.com/biancheng/370127.html 转载请保留说明!

上一篇:使用Script元素发送JSONP请求的方法(script在html中的用法)

下一篇:深入解析JavaScript中的arguments对象(深入解析windows第7版)

  • 企业缴纳季度所得税
  • 年前采购
  • 行政单位其他收入包括哪些
  • 公允价值变动损益和投资收益区别
  • 个人所得税交税怎么交的
  • 固定资产账实不符的审计定性
  • 结存材料物资会计分录怎么做?
  • 无形资产的累计摊销是什么意思
  • 个人所得税中的股息红利应纳税额
  • 银行付款退汇怎么做账
  • 企业长期待摊费用包括
  • 勾选认证和扫描认证哪个好
  • 开票资料上的电话可以是手机吗?
  • 以前固定资产入账折旧怎么提
  • 购买超市购物卡打几折
  • 车提折旧会计分录
  • 公司基本户买理财产品,怎么记账
  • 国际货运运费的计算基础
  • 微信收入与支出是怎么算的
  • 事业单位工资及薪酬好的单位有哪些
  • 企业所得税汇算表
  • smtplib教程
  • 评估价格是按原值还是净值
  • 商品流通会计科目
  • 确认收入的必要条件
  • 营改增全面推开为什么还叫试点
  • php跨域解决方案
  • 无法连接到你的相机,请重启手机
  • 会计上社保的分录是什么
  • 记账凭证账务处理步骤
  • 企业通讯费管理办法
  • 新事业单位会计准则
  • 工地临时设施搭设原则是什么?
  • php和ajax
  • 没有以前年度损益调整属于哪类科目
  • Yii2 assets清除缓存的方法
  • 微信公众号模板软件
  • patriotic研究
  • redis常见问题解决
  • 餐饮店库存盘点表
  • 公司银行开户的费用怎么做账
  • 分公司以总公司名义
  • python列表排序sorted
  • nosql manager for mongodb
  • 短期借款利息是多少
  • 公司注销前账务怎么处理好
  • 土地增值税要计入税金及附加吗
  • 库存现金的账务处理流程
  • 单位的车辆
  • 增值税专用发票的税率是多少啊
  • 税种分类及其税率
  • 认缴制下实收资本可以减少吗
  • 所得税不退税怎么写情况说明
  • 递延纳税筹划策略研究
  • 企业防止股权收益的措施
  • 银行总账和明细账
  • 离岸服务外包收入
  • 股权转让如何支付利润
  • 核定征收需要带什么资料
  • 缴纳工会经费如何记账
  • sql server发布
  • 计算机二级考试一年考几次
  • ubuntu系统升级命令
  • linux命令rz -y
  • centos7如何添加永久静态路由
  • linux ultrasphinx Anonymous modules have no name to be referenced by
  • mac如何全屏窗口
  • 使用windows管理无线
  • win8.1应用商店下载位置
  • fedora开机启动版本太多
  • Android OpenGL ES(九)----构建几何物体
  • js强制把网址设为密码
  • shell正则表达式匹配文件名
  • jquery中的基本选择器有哪些
  • jquery.serialize() 函数语法及简单实例
  • 增值税进项发票勾选时间
  • 电子发票软件怎么打开
  • 车船税可以异地补办吗
  • 费减备案合格后怎么操作?
  • 美国对中国商品征收关税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设