位置: 编程技术 - 正文

jquery中ajax处理跨域的三大方式

发布时间:2024-02-27

推荐整理分享jquery中ajax处理跨域的三大方式,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

由于JS同源策略的影响,因此js只能访问同域名下的文档。因此要实现跨域,一般有以下几个方法:

一、处理跨域的方式:

1.代理

2.XHR2

HTML5中提供的XMLHTTPREQUEST Level2(及XHR2)已经实现了跨域访问。但ie以下不支持

只需要在服务端填上响应头:

3.jsonP

原理:

ajax本身是不可以跨域的,通过产生一个script标签来实现跨域。因为script标签的src属性是没有跨域的限制的。

其实设置了dataType: 'jsonp'后,$.ajax方法就和ajax XmlHttpRequest没什么关系了,取而代之的则是JSONP协议。JSONP是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问。

ajax的跨域写法:

(其余写法和不跨域的一样):

比如

二、解决ajax跨域访问、 JQuery 的跨域方法

jquery中ajax处理跨域的三大方式

JS的跨域问题,我想很多程序员的脑海里面还认为JS是不能跨域的,其实这是一个错误的观点;有很多人在网上找其解决方法,教其用IFRAME去解决的文章很多,真有那么复杂吗?其实很简单的,如果你用JQUERY,一个GETJSON方法就搞定了,而且是一行代码搞定。

下面开始贴出方法。

注意,getregion.aspx中,在输出JSON数据时,一定要用Request.QueryString["jsoncallback"],将获取的内容放到返回JSON数据的前面,假设实际获取的值为,那么返回的值就是 ([{"_name":"湖南省","_regionId":},{"_name":"北京市","_regionId":}])

因为getJSON跨域的原理是把?随机变一个方法名,然后返回执行的,实现跨域响应的目的。

下面一个是跨域执行的真实例子:

jQuery跨域原理:

浏览器会进行同源检查,这导致了跨域问题,然而这个跨域检查还有一个例外那就是HTML的<Script>标记;我们经常使用<Script>的src属性,脚本静态资源放在独立域名下或者来自其它站点的时候这里是一个url;这个url响应的结果可以有很多种,比如JSON,返回的Json值成为<Script>标签的src属性值.这种属性值变化并不会引起页面的影响.按照惯例,浏览器在URL的查询字符串中提供一个参数,这个参数将作为结果的前缀一起返回到浏览器;

看下面的例子:

这种方式被称作JsonP;(如果链接已经失效请点击这里:JSONP);即:JSON with padding 上面提到的前缀就是所谓的“padding”。那么jQuery里面是怎么实现的呢?

貌似并没有<Script>标记的出现!?OKay,翻看源码来看:

页面调用的是getJSON:

继续跟进

跟进jQuery.ajax,下面是ajax方法的代码片段:

上面的代码第1行到第行:判断是JSON类型调用,为本次调用创建临时的JsonP方法,并且添加了一个随机数字,这个数字源于用日期值;

关注第行,这一行相当关键,注定了我们的结果最终是<Script> ;然后是构造Script片段,第行在Head中添加该片段,修成正果;

不仅仅是jQuery,很多js框架都是用了同样的跨域方案,这就是getJSON跨域的原理。

更多精彩内容,请点击《ajax跨域技术汇总》,进行深入学习和研究。

标签: jquery中ajax处理跨域的三大方式

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

上一篇:实例详解jQuery结合GridView控件的使用方法(jquery示例)

下一篇:jQuery实现二级下拉菜单效果(jquery二级导航栏)

  • 受票方与付款方不一致
  • 个人所得税手续费返还增值税税率
  • 购入房产计入什么科目
  • 增值税的视同销售行为有哪些
  • 土地摊销账务处理
  • 实收资本印花税率是多少啊
  • 个税返还款要交增值税吗
  • 税控盘及维护费的会计分录
  • 个体户转一般纳税人怎么做账
  • 社保公积金计提是本月计提下月
  • 叉车折旧年限是多少年
  • 营改增后企业所得税怎么算
  • 个体户对公账户怎么办理
  • 补贴收入计入哪个科目
  • 工程未竣工如何结算
  • 行政单位办公室主任必须是党员吗
  • 出口退税征税
  • 是不是所有的进口药都不能报销
  • 人防设施建设费
  • 计算本月生产成本怎么算
  • 付了款没有收到发票
  • 库存现金长短款怎么算
  • 土地增值税含房产吗
  • 坏账准备确认后可以转回吗
  • 税务师入会与不入会冲突
  • 笔记本cpu天梯图苹果
  • RAVMOND.exe - RAVMOND是什么进程.有什么作用
  • 普通发票主营业务收入销项负数发票怎么做账
  • 港口机场铁路
  • 会计科目备抵科目都有哪些
  • 基础代谢
  • 常用的3个第三方类库
  • Centos6.5和Centos7 php环境搭建方法
  • 我的第一次作文400字左右
  • c语音进阶
  • 买税盘的会计分录
  • python如何删除字典中的键值对
  • mysql中regexp_replace函数的使用
  • 企业用车年检需要什么资料
  • 织梦数据库连接失败的原因
  • 待摊费用多久摊销一次
  • python里eval的用法
  • 无形资产资产处置损益怎么算
  • 收付实现制的适用范围
  • 预算收入的退付范围
  • 报销差旅费会计分录退回现金
  • 行政单位应缴财政税金
  • 业务招待费税前扣除标准2020
  • 企业成本核算项目以及成本核算流程
  • 样板房装修可以住人吗
  • 企业发生的开办费用计入营业外支出账户
  • 管理费用和营业费用的比例
  • 现金支票存根联丢失怎么办
  • 销售费用的会计分录摘要
  • 员工办理健康证介绍信模板
  • 去年的会计凭证做错了,今年发现要怎么修改
  • 原始凭证的基本内容
  • sql储存过程
  • 多表关联执行顺序
  • windows无法启动wlanautoconfig服务
  • window10怎么设置蓝牙
  • csinject.exe是什么程序的进程 csinject进程是安全的吗
  • Win10怎么修改hosts文件
  • win10打开小娜
  • win10 19043.1237
  • 测试模式win8专业版 9200
  • win10组策略编辑器没有
  • shader cull
  • 一个项目引多个项目
  • unicode 字符百科
  • pycharm远程调试代码
  • javascript entries
  • 如何搭建node服务器
  • python urljoin
  • android强制关机
  • android缓存机制
  • 重庆国家税务局发票查询
  • 海口市地税局高峰简历
  • 安徽省各地区最低录取中考分数线
  • 会计报表错误
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号