<script type="text/javascript" src="./whenReady.js"></script>
<script type="text/javascript">
/**
* 一:跨域请求
*
* 这个常见的JavaScript模块查询有href属性但没有title属性的所有<a>元素
* 并给他们注册onmouseover事件处理程序
* 这个事件处理程序使用XMLHttpRequest HEAD请求取得链接资源的详细信息
* 然后把这些详细信息设置为链接的title属性
* 这样他们将会在工具提示中显示
*/ whenReady(function(){
//是否有机会使用跨域请求
var supportCORS = (new XMLHttpRequest()).withCredentials !==undefined; //遍历文档中的所有链接
var links = document.getElementsByTagName('a');
for(var i = 0 ; i < links.length ; i++){
var link = links[i];
if(!link.href)
continue; //跳过没有超链接的锚点
if(link.title)
continue; //跳过已经有工具提示的链接 //如果这是一个跨域链接
if(link.host !== location.host || link.protocol !== location.protocol){
link.title = "站外链接"; //假设我们不能得到任何信息
if(!supportCORS)
continue; //如果没有CORS支持就退出
//否则,我们能了解这个链接的更多信息
//所以继续前进,注册事件处理程序,于是我们可以尝试
} //注册事件处理程序,当鼠标悬停下载链接详细信息
if(link.addEventListener)
link.addEventListener("mouseover",mouseoverHandler,false);
else
link.attachEvent("mouseover",mouseoverHandler);
} function mouseoverHandler(e){
var link = e.target || e.srcElement; //<a>元素
var url = link.href; //链接url var req = new XMLHttpRequest(); //新请求
req.open("HEAD",url); //仅仅询问头信息
req.onreadystatechange = function(){ //事件处理程序
if(req.readyState !== 4)
return; //如果未完成,直接返回
if(req.status ===200){ //如果成功
var type = req.getResponseHeader("Content-Type"); //获取链接的详细情况
var size = req.getResponseHeader("Content-Length");
var data = req.getResponseHeader("Last-Modified"); //在工具提示中显示详细信息
link.title = "类型:"+type+"\n"+"大小:"+size+"\n"+"时间:"+date;
}else{
//如果请求失败,且链接没有“站外链接”的工具提示
//那么显示这个错误
if(!link.title)
link.title = "Couldn't fetch details:\n"+req.status+" "+req.statusText;
}
};
req.send(null); //移除处理程序,仅想一次获取这些头信息
if(link.removeEventListener)
link.removeEventListener("mouseover",mouseoverHandler,handler);
else
link.detachEvent("onmouseover",mouseoverHandler);
}
}); /**
* 二:借助<script>发送http请求:JSONP
*根据指定的url发送一个JSONP请求
*然后把解析得到的响应数据传递给回调函数
*在URL添加一个名为jsonp的查询参数,用于指定请求的回调函数的名称
*/
function getJSONP(url,callback){
//为本次请求创建一个唯一的回调函数名称
var cbnum = "cb"+getJSONP.counter+++; //每次自增计数器
var cbname = "getJSONP."+cbnum; //作为JSONP函数的属性 //将回调函数名称一以表单编码的形式添加到URL的查询部分中
//使用jsonp作为参数名,一些支持JSONP的服务
//可能使用其他的参数名,比如:callback
if(url.indexOf("?") === -1 ) //url没有查询部分
url+="?jsonp="+cbname; //作为查询部分添加参数
else //否则
url += "&jsonp"+cbname; //作为新的参数添加它 //创建script元素用于发送请求
var script = document.createElement("script"); //定义将被脚本执行的回调函数
getJSONP[cbnum] = function(response){
try{
callback(response); //处理响应数据
}
finally{ //即使回调函数或响应抛出错误
delete getJSONP[cbnum]; //删除给函数
script.parentNode.removeChild(script); //移除script元素
}
};
//立即出发http请求
script.src = url; //设置脚本的url
document.body.appendChild(script); //把它添加都文档中
}
getJSONP.counter = 0; //用于创建唯一回调函数名称的计数器
</script>

  

JavaScript跨域请求和jsonp请求实例的更多相关文章

  1. XHR的跨域请求和JSONP详解

    首先:什么是跨域? Cross Domain Request:从一个资源请求另一个资源,二者所在的请求地址不同,域名不同.端口号不同.请求协议不同. 它是由浏览器的同源策略造成的,是浏览器对JavaS ...

  2. JavaScript跨域调用、JSONP、CORS与ASP.NET Web API[共8篇]

    [第1篇] 同源策略与JSONP 浏览器是访问Internet的工具,也是客户端应用的宿主,它为客户端应用提供一个寄宿和运行的环境.而这里所说的应用,基本是指在浏览器中执行的客户端JavaScript ...

  3. JavaScript 跨域:谈谈跨域之 JSONP

    在 Web 开发中,后台开发人员应该会通常遇到这个问题:跨域,而使用 JSONP 就是其中解决办法之一,当然,还有其它解决方法,比如:window.name.window.postMessage.CO ...

  4. thinkphp,javascript跨域请求解决方案

    javascript跨域请求解决方案 前言 对于很多前端或者做混合开发的同学,我们难免会遇到跨域发起请求业务,比如A站点向B站点请求数据等等.由于最近要做一个站点集群的项目,所以具体业务要求很多个站点 ...

  5. jQuery(三) javascript跨域问题(JSONP解决)

    加油~ --WH 一.什么是javascript跨域问题? 域:服务器域名,唯一标识(协议,域名,端口)必须保证一致,说明域相同 跨域:在一个服务器上,去访问另一个服务器上,并且得到另一个服务器返回回 ...

  6. JSONP跨域的script标签请求为什么不受同源策略的限制?

    在复习跨域的时候,复习到了JSONP跨域,大家都知道JSONP跨域是通过动态创建script标签,然后通过其src属性进行跨域请求的,前端需要一个数据处理的回调函数,而服务端需要配合执行回调函数,放入 ...

  7. javascript 跨域问题 jsonp

    转载:http://www.cnblogs.com/choon/p/5393682.html demo 用动态创建<script></script>节点的方式实现了跨域HTTP ...

  8. 说一说javascript跨域和jsonp

    同源策略 在浏览器的安全策略中“同源策略”非常如雷贯耳,说的是协议.域名.端口相同则视为同源,域名也可换成IP地址,不同源的页面脚本不能获取对方的数据. 要是想使用XMLHttpRequest或者常规 ...

  9. JavaScript 跨域漫游

    前言: 最近在公司做了几个项目都涉及到了iframe,也就是在这些iframe多次嵌套的项目中,我发现之前对iframe的认识还是比较不足的,所以就静下心来,好好整理总结了iframe的相关知识:&l ...

随机推荐

  1. 冒泡排序的python代码实现

    li = [33, 2, 10, 1,564,880,8,99,51,3]# for i in range(len(li) - 1):#     current = li[i]#     next_v ...

  2. 小小白的python之路------python基础01

    1. 不说python是啥了,百度一堆.,还是说说我学了啥 我说的是python3.5,其他的自己看着办 这个是下载链接啊,自己玩 https://www.python.org/ 我下载完成,使用py ...

  3. 基于NIO的Netty网络框架

    Netty是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机制,用户可以方便的主动获取或者 ...

  4. Linux命令不熟悉(记录)

    1.回到上一次操作的目录 cd - 2.rz打开上传文件 rz 3.下载某个文件 wget httpdownload 4.根据名字查找文件 find / -name mysql 5.通配符删除 rm ...

  5. css3的学习

    已经学习css3一个月了,通过对css3的深入学习,我对网页设计的理解就更深刻了,以前只会用简单的图片,定位等来制作网页,现在可以运用css3扩展的新内容来写出更好看的网页. css3扩展内容中,我认 ...

  6. 关于log4.net 错误,求解

    1.上结果 能生成文件 ,但是文件中无内容 2.配置文件 <configSections> <section name="log4net" type=" ...

  7. python os模块学习

    一.os模块概述 Python os模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话,这个模块是尤为重要的. 二.常用方法 1.os.name 输出字符串指示正在使用的平台.如果是wi ...

  8. Django中通过filter和simple_tag为前端实现自定义函数

    Django的模板引擎提供了一般性的功能函数,通过前端可以实现多数的代码逻辑功能,这里称之为一般性,是因为它仅支持大多数常见情况下的函数功能,例如if判断,ifequal对比返回值等,但是稍微复杂一些 ...

  9. python+selenium遇到鼠标悬停不成功可以使用js进行操作

    问题:在定位这种悬停后出现下拉操作的时候,尝试了使用move_to_element的方法 # ele_logout = br.find_element_by_xpath('/html/body/div ...

  10. Caused by: java.lang.RuntimeException: by java.lang.OutOfMemoryError: PermGen space(tomcat 启动时提示内存溢出)

    设置MaxPermSize大小TOMCAT_HOME/bin/catalina.bat 文件头加set JAVA_OPTS='-Xms512m -Xmx1024m -XX:MaxPermSize=51 ...