位置: 编程技术 - 正文

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

  • 税金及附加需要计提吗
  • 印花税技术合同计税依据
  • 年报资产总额是期末余额吗
  • 库存现金期末余额
  • 小规模纳税人发票怎么做账
  • 融资租赁本金和租金的区别
  • 库存现金贷方为负数说明什么
  • 合同租金总收入怎么填
  • 没有及时取得发票可以入成本么
  • 一般纳税人交增值税会计科目
  • 提取法定盈余公积比例
  • 凭证可以部分冲销吗
  • 无偿代建政府公告
  • 电子发票怎么红冲步骤视频
  • 劳务公司开的专票需要交税吗
  • 自助开税票流程
  • 异地开票需要在当地交税吗
  • 关于7.1号增值税普通发票新规
  • 社保滞纳金税前怎么算
  • 银行账户基本户是什么意思
  • 小规模纳税人财务报表是按季还是按月申报
  • 当无法取得对应报价时,将以即时现价报单
  • 期末结转生产成本会计分录
  • 发生的业务招待费属于什么科目
  • 收境外的钱
  • 融资租赁哪些项目可以增值税抵扣
  • 核定征收的企业利润怎么处理
  • 签证费会计分录
  • 财政拨款的贴息怎么计算
  • 司机公里补贴进什么科目
  • 计提安全费用含税还是不含税
  • PHP:oci_define_by_name()的用法_Oracle函数
  • php wechat
  • laravel获取请求参数
  • 生产成本结转后有余额吗
  • php接口技术
  • chrome os安装到u盘
  • 身份证号码的正确读法
  • python输入三科成绩
  • discuz怎么添加diy模块
  • ps位图矢量化
  • python进行统计分析
  • 公司的归属权
  • 企业交的社保包含什么
  • 商业承兑汇票贴现会计分录
  • 保理属于什么行业分类
  • 预算收入支出
  • 什么是指社会保障完全靠当前的收入
  • 存款利息收入应计入收入总额吗
  • 增值税专用发票查询系统官方网站
  • 租入的房子再出租用交房产税吗?
  • 不动产产权的取得
  • 费用报销单的摘要和报销项目怎么写
  • 未取得合法支付凭据和与本单位无关的收入
  • mysql检查表是否存在
  • 如何关闭win10自带杀毒软件
  • ubuntu20.04安装配置
  • mac ios应用
  • linuxmail命令
  • mac如何预览字体大小
  • 获取windows的最新信息
  • linux必学的60个命令及使用
  • win8账户锁定无法登录
  • cocos2dx如何通过Image获取指定点颜色值
  • cocos2dx在不同安卓机型下scrollview裁剪失败
  • c#+unity3d
  • Ubuntu12.04(X86_64)上安装Mesa-8.0.4
  • javascript date函数
  • js跨域8种解决方案
  • node.js的作用是什么
  • 基于怎么用
  • 一周总结家长寄语
  • js字符串转为json
  • javascript详细介绍
  • 用js实现类的方法
  • jQuery simpleModal插件的使用介绍
  • javascript中继承
  • 淄博市地税局局长
  • 一般纳税人注销公司需要查账吗
  • 进出口货物的报关时限
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设