位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享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二级导航栏)

  • 计提的增值税和实际缴纳的差额
  • 房地产开发企业预缴增值税
  • 工程奖励金算收入吗
  • 去年收到一张普票超范围了怎么办
  • 工资中代扣款是什么
  • 公司名称变更在哪个网站
  • 机票的抵扣进项怎么抵扣
  • 企业收到补贴需要开票吗
  • 融资租入固定资产的入账价值
  • 承兑汇票怎么做假
  • 进项税转出申报表能填负数吗
  • 什么是差额增收
  • 跨月发票作废怎么操作流程
  • 办理完税务手续是否还需要报税?
  • 营改增后挂靠开票作收入吗?
  • 一般纳税人当月只有进项没有销项怎么做账
  • 易票365是哪家公司的
  • 增值税小规模纳税人申报表填表说明
  • 未办理土地使用证违反了什么法律
  • 法人变更了之前的支票还能进账吗?
  • 免抵税额增值税主表体现到哪里的
  • 进项大于销项怎么做账
  • 简易征收是优惠政策吗
  • 企业未代扣代缴个税
  • 清卡信息还未生成请稍后再试什么意思
  • 增值税转型后入账价值
  • 1697510742
  • com2us密码找回
  • 财政拨款收入属什么科目
  • 分配的水电费属于什么会计要素
  • 怎么增加c盘空间容量
  • 公司购买货物
  • ant design vue vue3
  • php定时执行代码
  • 差旅费的会计分录怎么做
  • 前端没思路怎么办
  • 劳务公司给包工头打款备注写什么
  • 天猫提现到对公账户怎么做账
  • php分页技术
  • react组件constructor
  • vmstat命令 监视系统资源状态
  • 高德地图的2种导航方式
  • 未达起征点怎么填申报表
  • 新会计准则分录大全
  • mongodb subtract
  • 资本性支出与资本性支出(基本建设)的区别
  • 计提工资大于发放工资,所得税汇算要调整吗
  • 有限合伙企业属于企业法人还是非法人企业
  • 钢管扣件租赁公司账务处理
  • 金税卡就是税控盘吗
  • 跨月的增值税普通发票能作废吗
  • 转让旧固定资产怎么处理
  • 建造合同信息表
  • 投资性房地产抵债怎么做账务处理
  • 劳务费个人所得税核定征收
  • 库存和结存
  • 私募基金公司收入高吗
  • 安装生产流水线工程领用原材料
  • 企业增值税额
  • 固定资产清理费用账务处理
  • 房地产企业预付账款会计分录
  • 新开公司没有领失业金
  • 财务会计的基本概念
  • 发票盖章需要知道的10个问题
  • 单位存款的种类有哪些
  • mysql 5.6.26 winx64安装配置图文教程(一)
  • MYSQL数据库原理及应用
  • win10提高
  • xp输入法图标消失
  • 写出10个linux系统操作命令和用法
  • linux内核怎么使用
  • jQuery.trim() 函数及trim()用法详解
  • linux nodejs
  • 恶意软件清理
  • Python 数据清洗
  • node的express
  • jquery中绑定和解绑的事件有哪些
  • javascript基础入门视频教程
  • 企业代缴房产税可以入账吗
  • 福州台江区怎么去
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设