js实现跨域的几种方法汇总(图片ping、JSONP和CORS)


Posted in Javascript onOctober 25, 2015

跨域

虽然有同源策略的存在,但是在js中跨域也依然很常见,有document.domain、window.name、图片ping、jsonp、CORS,在这里简单总结下图片ping、jsonp和CORS备忘。

图片ping

图片可以从任何URL中加载,所以将img的src设置成其他域的URL,即可以实现简单的跨域,可以使用onload和onerror事件来确定是否接受到了响应。

var img=new Image();
img.src='https://3water.com';
img.onerror=function(){
 alert('error');
}
img.onload=function(){
 alert('success');
}

这里新建了一个img对象,给出的url是博客地址,这里是个error事件,所以弹出error;如果将URL改为一张图片http://images.3water.com//710118/o_MacBook%20Air.png,就会弹出onload加载信息success,从而实现了简单的跨域。

使用图片ping跨域只能发送get请求,并且不能访问响应的文本,只能监听是否响应而已,可以用来追踪广告点击。

jsonp

jsonp是带有回调函数callback的json,原名json with padding,翻译是填充式json,参数式json。

因为script的src可以跨域,所以在发送的URL后添加一个callback参数传递给服务器,然后服务器返回的数据会作为callback的参数,因为这个callback是我们自己来实现的,所以可以对接受到的json数据进行处理。

简单代码如下:

<script type="text/javascript">
function call(data){
 alert(data.city);
}
</script>
<script type="text/javascript" src='http://freegeoip.net/json/?callback=call'></script>

这里,我们把脚本的src设置为http://freegeoip.net/json/?callback=call,这是一个获取用户ip地址的api(有兴趣的可以点击这里查看),然后将callback作为一个参数拼接在URL后,返回的json数据就会作为callback的参数,在这里callback我们定义为call函数,即返回的json数据就会作为call的参数传进去,这个call函数仅仅弹出用户的城市city。笔者这里的输出结果是河北。其他ip信息可以查看官网,上面有详细的列表,比如country_name,time_zone等。

CORS(跨资源共享)

CORS是跨资源共享,cross site resourse sharing,它和ajax其实是大体相同的,对于ie实例化的是xdr对象,XDomainRequest,我们能访问的也只有responseText,触发的事件有load和error,写法和xhr大体相同,也需要open和send。

对于ff,chrome等其他浏览器实例化的是xhr,在这里myvin仅仅拿xhr来演示下,如果要实现跨浏览器,可以配合xdr实现兼容。

xhr如下:

var xhr=new XMLHttpRequest();   
var url="https://3water.com";
xhr.open('GET', url); 
xhr.send(null);

这里使用的url是https://3water.com,和ajax唯一的区别就是url使用的是跨域的绝对地址,在ajax中使用的本页面内的相对地址或绝对地址。

看一下控制台,这里用的是ff40.0.3,显示信息如下:

已阻止跨源请求:同源策略禁止读取位于 https://3water.com 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。

所以用CORS实现跨域还有一步要做,就是在服务器端设置Access-Control-Allow-Origin。

Javascript 相关文章推荐
基于jquery的finkyUI插件与Ajax实现页面数据加载功能
Dec 03 Javascript
2010年最佳jQuery插件整理
Dec 06 Javascript
巧用局部变量提升javascript性能
Feb 24 Javascript
js的hasownproperty使用示例
Mar 02 Javascript
JS数组交集、并集、差集的示例代码
Aug 23 Javascript
探索webpack模块及webpack3新特性
Sep 18 Javascript
基于vue-ssr服务端渲染入门详解
Jan 08 Javascript
微信小程序scroll-view仿拼多多横向滑动滚动条
Apr 21 Javascript
JS隐藏号码中间4位代码实例
Apr 09 Javascript
javascript 原型与原型链的理解及实例分析
Nov 23 Javascript
vue实现计算器功能
Feb 22 Javascript
详解Vue3 Teleport 的实践及原理
Dec 02 Vue.js
详解JavaScript编程中的数组结构
Oct 24 #Javascript
向JavaScript的数组中添加元素的方法小结
Oct 24 #Javascript
jQuery实现鼠标经过事件的延时处理效果
Aug 20 #Javascript
使用jquery动态加载Js文件和Css文件
Oct 24 #Javascript
JavaScript中数组的合并以及排序实现示例
Oct 24 #Javascript
使用javaScript动态加载Js文件和Css文件
Oct 24 #Javascript
js判断日期时间有效性的方法
Oct 24 #Javascript
You might like
php Xdebug 调试扩展的安装与使用.
2010/03/13 PHP
让PHP显示Facebook的粉丝数量方法
2014/01/08 PHP
PHP错误处理函数
2016/04/03 PHP
浅析Laravel5中队列的配置及使用
2016/08/04 PHP
PHP url的pathinfo模式加载不同控制器的简单实现
2016/08/12 PHP
PHP调试及性能分析工具Xdebug详解
2017/02/09 PHP
Mootools 1.2教程 Fx.Morph、Fx选项和Fx事件
2009/09/15 Javascript
Extjs Ext.MessageBox.confirm 确认对话框详解
2010/04/02 Javascript
js获取height和width的方法说明
2013/01/06 Javascript
jquery和ajax的关系详细介绍
2013/11/29 Javascript
js for循环倒序输出数组元素的实例
2017/03/01 Javascript
在vue项目中引用Iview的方法
2018/09/14 Javascript
Vue请求JSON Server服务器数据的实现方法
2018/11/02 Javascript
VUE简单的定时器实时刷新的实现方法
2019/01/20 Javascript
vue 解决数组赋值无法渲染在页面的问题
2019/10/28 Javascript
javascrpt密码强度校验函数详解
2020/03/18 Javascript
javascript中正则表达式语法详解
2020/08/07 Javascript
python写xml文件的操作实例
2014/10/05 Python
Django中Model的使用方法教程
2018/03/07 Python
TensorFlow数据输入的方法示例
2018/06/19 Python
python实现生成Word、docx文件的方法分析
2019/08/30 Python
Python如何使用字符打印照片
2020/01/03 Python
Python 字符串处理特殊空格\xc2\xa0\t\n Non-breaking space
2020/02/23 Python
基于Python模拟浏览器发送http请求
2020/11/06 Python
python3爬虫中引用Queue的实例讲解
2020/11/24 Python
pytorch 实现L2和L1正则化regularization的操作
2021/03/03 Python
html5 postMessage解决跨域、跨窗口消息传递方案
2016/12/20 HTML / CSS
军训的自我鉴定
2013/12/10 职场文书
违反工作纪律检讨书
2014/02/15 职场文书
中式婚礼主持词
2014/03/13 职场文书
领导工作表现评语
2015/01/04 职场文书
驳回起诉裁定书
2015/05/19 职场文书
幼儿园安全教育随笔
2015/08/14 职场文书
《岳阳楼记》原文、译文赏析
2019/09/10 职场文书
redis不能访问本机真实ip地址的解决方案
2021/07/07 Redis
利用JavaScript写一个简单计算器
2021/11/27 Javascript