HTML5之XMLHttpRequest Level 2 API跨源运用案例
2017-07-20 00:53
435 查看
大家都知道XMLHttpRequest API使得Ajax技术的实现成为了可能。作为XMLHttpRequest的改进版,XMLHttpRequest Level 2在功能上有了很大的改进。主要体现在以下两个方面:
跨源XMLHttpRequest ;
进度事件 (Progress events)
在过去,XMLHttpRequest 仅限于同源通信。XMLHttpRequest Level 2通过CORS(跨源资源共享)实现了XMLHttpRequests。CORS规范要求,对一些敏感行为——如申请证书的请求或除了GET和POST以外的OPTIONS预检请求,必须由浏览器发送给服务器,以确定这种行为能否被支持和允许了,这意味着成功通信的背后或许需要由具备CORS处理能力的服务器来支持。
新版XMLHttpRequest
中最重要的API改进之一是增加了对进度的响应。在XMLHttpRequest之前的版本中,仅有readystatechange一个事件能够被用来响应速度。更糟糕的是,浏览器对该事件的实现并不兼容,如在IE中永远都不会触发readystate 3。
前提条件:首先,页面需要部署在web服务器上;其次,两个页面必须来自不同的域。
127.0.0.1文件crossOriginUpload.html
<?php
header('HTTP/1.1 200 OK');
header('Access-Control-Allow-Origin: http://127.0.0.1');
$REQUEST_METHOD = $_SERVER['REQUEST_METHOD'];
switch (strtoupper($REQUEST_METHOD)) {
case 'POST':
$message = '数据上传完成';
header('Content-Length: '.strlen($message));
header('Content-Type: text/plain');
break;
case 'OPTIONS':
header('Access-Control-Allow-Methods: POST');
header('Access-Control-Allow-Headers: Content-Type');
break;
}
结果截图:
跨源XMLHttpRequest ;
进度事件 (Progress events)
在过去,XMLHttpRequest 仅限于同源通信。XMLHttpRequest Level 2通过CORS(跨源资源共享)实现了XMLHttpRequests。CORS规范要求,对一些敏感行为——如申请证书的请求或除了GET和POST以外的OPTIONS预检请求,必须由浏览器发送给服务器,以确定这种行为能否被支持和允许了,这意味着成功通信的背后或许需要由具备CORS处理能力的服务器来支持。
新版XMLHttpRequest
中最重要的API改进之一是增加了对进度的响应。在XMLHttpRequest之前的版本中,仅有readystatechange一个事件能够被用来响应速度。更糟糕的是,浏览器对该事件的实现并不兼容,如在IE中永远都不会触发readystate 3。
前提条件:首先,页面需要部署在web服务器上;其次,两个页面必须来自不同的域。
127.0.0.1文件crossOriginUpload.html
<!DOCTYPE html> <title>上传数据</title> <link rel="stylesheet" href="styles.css"> <script> function loadDemo() { var dataElement = document.getElementById("geodata"); dataElement.textContent = JSON.stringify(geoData).replace(",", ", ", "g"); //XMLHttpRequest浏览器支持情况检测 var xhr = new XMLHttpRequest();//为了构建跨源XMLHttpRequest,首先创建一个新的XMLHttpRequest对象 if (typeof xhr.withCredentials === undefined) { document.getElementById("support").innerHTML = "您的浏览器<strong>不支持</strong>XMLHttpRequest跨域"; } else { document.getElementById("support").innerHTML = "您的浏览器<strong>支持</strong>XMLHttpRequest跨域"; } var targetLocation = "http://www.vserve365.com/process.php"; function setProgress(s) { document.getElementById("progress").innerHTML = s; } //XMLHttpRequest Level 2不再使用数值型状态表示法,而是提供了命名进度事件。为事件处理程序属性设置相应的回调函数,就可以对这些事件进行监听了。 //在请求过程中务必确保能够监听到错误。请求不成功有很多原因,如网络故障、访问被拒、目标服务器缺乏对CORS的支持等。
document.getElementById("sendButton").addEventListener("click", function() { xhr.upload.onprogress = function(e) { var ratio = e.loaded / e.total; setProgress(ratio + "%被上传");//计算上传的完成率 } xhr.onprogress = function(e) { var ratio = e.loaded / e.total; setProgress(ratio + "%被下载");//计算下载的完成率 } xhr.onload = function(e) { setProgress("完成"); } xhr.onerror = function(e) { setProgress("出错"); } xhr.open("POST", targetLocation, true);//通过指定不同源的地址来构造跨源XMLHttpRequest geoDataString = dataElement.textContent; xhr.send(geoDataString); }, true); } window.addEventListener("load", loadDemo, true); </script> <h1>XMLHttpRequest Level 2</h1> <p id="support"></p> <h4>将被上传的数据:</h4> <textarea id="geodata"> </textarea> </div> <button id="sendButton">上传</button> <script> geoData = [[39.080018000000003, 39.112557000000002, 39.135261, 39.150458, 39.170653000000001, 39.190128000000001, 39.204510999999997, 39.226759000000001, 39.238483000000002, 39.228154000000004, 39.249400000000001, 39.249533, 39.225276999999998, 39.191253000000003, 39.167993000000003, 39.145685999999998, 39.121620999999998, 39.095761000000003, 39.080593, 39.053131999999998, 39.02619, 39.002929000000002, 38.982886000000001, 38.954034999999998, 38.944926000000002, 38.919960000000003, 38.925261999999996, 38.934922999999998, 38.949373000000001, 38.950133999999998, 38.952649000000001, 38.969692000000002, 38.988512999999998, 39.010652, 39.033088999999997, 39.053493000000003, 39.072752999999999], [-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999],[-120.15724399999999, -120.15818299999999, -120.15600400000001, -120.14564599999999, -120.141285, -120.10889900000001, -120.09528500000002, -120.077596, -120.045428, -120.0119, -119.98897100000002, -119.95124099999998, -119.93270099999998, -119.927131, -119.92685999999999, -119.92636200000001, -119.92844600000001, -119.911036, -119.942834, -119.94413000000002, -119.94555200000001, -119.95411000000001, -119.941327, -119.94605900000001, -119.97527599999999, -119.99445, -120.028998, -120.066335, -120.07867300000001, -120.089985, -120.112227, -120.09790700000001, -120.10881000000001, -120.116692, -120.117847, -120.11727899999998, -120.14398199999999]]; </script> <p> <b>状态: </b> <span id="progress">准备</span> </p>远程服务器文件process.php
<?php
header('HTTP/1.1 200 OK');
header('Access-Control-Allow-Origin: http://127.0.0.1');
$REQUEST_METHOD = $_SERVER['REQUEST_METHOD'];
switch (strtoupper($REQUEST_METHOD)) {
case 'POST':
$message = '数据上传完成';
header('Content-Length: '.strlen($message));
header('Content-Type: text/plain');
break;
case 'OPTIONS':
header('Access-Control-Allow-Methods: POST');
header('Access-Control-Allow-Headers: Content-Type');
break;
}
结果截图:
相关文章推荐
- 大熊君学习html5系列之------XHR2(XMLHttpRequest Level 2)
- 大熊君学习html5系列之------XHR2(XMLHttpRequest Level 2)
- HTML5-XMLHttpRequest Level 2
- xmlhttprequest level 2
- [读书笔记]Communication API 之 XMLHttpRequest Level 2
- 【JavsScript】XMLHttpRequest Level 2 使用指南
- XMLHttpRequest 对象使用案例
- XMLHttpRequest Level 2 使用指南
- XMLHttpRequest Level 2 使用指南
- (转)Ajax_XMLHttpRequest Level 2
- XMLHttpRequest Level 2 使用指南
- 运用Ajax的xmlHttpRequest对象异步与后台交互并提示交互结果
- Porfessional JS(21.2-XMLHttpRequest Level 2/Progress Event/CORS)& Sharp jQuery(selectors[part])
- Introduction to XMLHttpRequest Level 2
- 通过html5 File、XMLHttpRequest实现文件上传
- HTML5 XMLHttpRequest中的新功能
- XMLHttpRequest Level 2 使用指南
- XMLHttpRequest Level 2 使用指南
- XMLHttpRequest Level 2 FormData 提交二进制文件
- XMLHttpRequest Level 2 使用指南