位置: 编程技术 - 正文

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二级导航栏)

  • 商品房销售税率10%执行时间
  • 全国税务师考试准考证打印
  • 建筑企业可以挂靠吗
  • 汇算清缴是不是按照审计报告
  • 实际已缴纳所得税额在汇算清缴报告里怎么看
  • 农副产品增值税免税政策
  • 子公司分红款没收到,宣告分红可以免税吗
  • 应收账款确认无法收回分录
  • 赠送产品能直接用吗
  • 印花税账务处理
  • 国税申报需要带什么资料
  • 企业所得税退税的会计分录怎么做
  • 2020深圳增值税税率是多少
  • 自产自销农产品企业所得税
  • 第三方代收代付平台
  • 发票抬头写个人税号怎么写
  • 销售单怎么设置打几行
  • 第三方软件测评费的取费标准
  • 拆除原有建筑物成本扣除
  • 怎么添加一个
  • windows所有应用
  • 投资收益亏损后会怎么样
  • 如何在苹果电脑上删除软件
  • 推广费开票属于什么费用
  • win10专业版用户名和密码怎么取消
  • PHP:mb_strrchr()的用法_mbstring函数
  • sudo命令无法执行
  • 税收保全措施的期限一般不超过几个月
  • 无法访问或访问被拒绝是怎么解决
  • 缴纳个税时怎么做分录
  • yolov5 教程
  • 一朵牛肝菌 (© vnosokin/Getty Images)
  • 购进设备抵扣税额
  • ts和js混用
  • 垃圾分类手工小模型
  • 表单验证方法一般有哪几种
  • php中定义函数
  • 农业合作社需要纳税吗
  • 农民工工资专用账户打款比例
  • 开票软件是什么名字
  • 其他综合收益在资产负债表中如何填列
  • 完美解决怠速抖动加油就平稳
  • sql数据库使用基本原理
  • 帝国cms伪静态规则
  • 融资租赁业务应包括哪些
  • 主营业务税金及附加和税金及附加的区别
  • sql server基本
  • sql如何设置远程连接
  • 银行对帐单
  • 研发费用加计扣除的条件
  • 积分兑换礼品需要什么
  • 预付一年的房租怎么做账
  • 每月增值税怎么做账
  • 外商投资企业清算资金汇出环节,银行
  • 挂靠企业电费如何处理?
  • 年初未分配利润在利润表怎么填
  • 工业企业会计和商业企业会计的区别
  • SQL Server Alwayson创建代理作业的注意事项详解
  • mssql server 2012(SQL2012)各版本功能对比
  • 数据库表的查询操作实验
  • sql2008设置单用户模式
  • debian9.6安装教程
  • mysql sql语句性能调优
  • win10的数据使用量是什么
  • unix系统的文件分为哪三种存取结构
  • linux带桌面
  • linux常用性能监控命令
  • win10预览体验推荐哪个通道
  • 上传图片 js
  • 用python编写登录程序
  • 读取fasta文件
  • node-red 全局变量
  • opencv for python
  • pygame实例
  • jquery设置禁用
  • gridlayout动态添加view
  • 税控盘离线开票时间超限是怎么回事
  • 苏州地方税务
  • 营业费用指哪些
  • 开票风险预警机制黄色预警严重吗?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设