位置: 编程技术 - 正文

跨域请求的完美解决方法(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版)

  • 建安增值税怎么计算
  • 已经认证抵扣的发票还能作废吗
  • 无形资产减值准备可以转回吗
  • 预缴增值税需要预缴附加税吗
  • 损益类科目是否可以转出
  • 小规模开专票附加税要计提吗
  • 经营所得税投资者减除费用
  • 非贸易付汇去银行汇款流程
  • 公司无收入费用如何做账务处理核算?
  • 广告业福利发放会计处理怎么做?
  • 蓝字发票作废流程视频
  • 公司分期付款买车可以抵税吗
  • 总资产现金回收率是什么与什么平均余额的比
  • 工会经费基数是上个月收到的工资还是什么
  • 固定资产赔偿制度
  • 跨区域经营增值税所得税预缴多少
  • 小规模咨询费税率是多少
  • 待认证进项税额转出会计分录
  • 开票方开错发票
  • 固定资产入账的方式
  • 员工垫付公司钱怎么入账
  • windows10如何开启vt
  • 原始股东减持要交多少税
  • 电脑软件如何开机自启动
  • linux中ping命令怎么用
  • 职业病治疗费用由谁来承担
  • js图片放大代码
  • exescope是什么软件
  • flex布局子元素height100
  • 详解金球奖之争
  • 转出未交增值税借方余额表示什么
  • 分包工程的账务处理
  • 印花税减半征收优惠政策2020
  • laravel 5.1下php artisan migrate的使用注意事项总结
  • 如何用python求解航天器追逃博弈
  • 年底计提成本
  • lvm命令详解
  • 【Discuz】实现主题标题和正文同时显示
  • 个人劳务费需交什么税种
  • 辞退补偿金计算
  • access如何设置宏的功能
  • mongodb 数据文件
  • sql防御
  • 一般纳税人支付的增值税计入成本吗
  • 应退或应补税额是负数
  • 珠宝可以开票抵扣吗
  • 企业所得税营业外收入
  • 销售额多少需要纳税
  • 公司购买办公用品会计分录
  • 关联表的作用
  • 暂估成本的账务怎么处理
  • 公司买车赠送给个人,怎么交税
  • 以前年度损益调整结转到哪里
  • 电动车折旧年限及残值
  • 固定资产的维修计入什么科目
  • 施工图审查费计入什么会计科目
  • mysql5.7.30安装
  • 一些有用的sql语句是什么
  • sql空值用什么表示
  • win10无法新建文件夹怎么办?(已解决)
  • mac怎么用知云翻译
  • 无法打开vmx86
  • 如何使用xp
  • mac wifi时断时续
  • welcome.exe - welcome进程是什么意思
  • 延长药品使用时间的方法
  • win8飞行模式在哪
  • cocos2dx4.0教程
  • opengl update
  • Extjs4 GridPanel的主要配置参数详细介绍
  • bat查看ip地址和mac地址
  • nodejs事件循环和js事件循环
  • koa2 koa
  • unity星球模型
  • 高博应诺官网
  • 控件begininvoke
  • 国家税务局浙江省电子税务局新版
  • 职称申报结束多久公示
  • 快递代缴的关税有税单吗
  • 华数tv业务认证账号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设