JS 跨域访问的几种方式

              最近公司项目涉及到了跨域访问,以前都是用jsonp解决该问题,但是jsonp的局限性在与只能使用get方式,导致对请求参数的长度有很大限制,且安全性不是很好,网上逛了逛,发现跨域解决的方案还是蛮多的


     jsonp

          1: 只能为GET方式.(所有参数明文且参数长度不能大于255)
  2: 请求数据有大小限制.(chrome为8k,firefox为7k,ie为2k),所以传输的数据量过大可能造成数据不完整.
          3: 兼容性为IE6+以及所有主流浏览器.


         

     cors

          1: html5新特性,方便好用支持post,get
          3: 兼容性是个巨坑,主要是IE9以下都不支持


          

     js+flash

          1: 原理同SWFUpload,借用flash插件进行ajax访问,插件:ajaxcdr
          2: 依赖flash插件,这个是很大的缺陷


           

     虚拟FORM

          1: 使用form表单进行模拟提交,然后通过监听onload事件监听返回结果,插件:XMan
          2: 一个不错的方式,但是form的提交后的结果监听不是很方便


         

       总结:

            最后还是使用了虚拟FORM的方式解决跨域问题,个人任务这个是考虑兼容性问题时最佳的跨域解决方案

           

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值