js-其他跨域技术(JSONP`Comet)
###1. JSONP
JSONP由两部分组成:回调函数和数据
JSONP是通过动态<script>元素来使用的,使用时可以为src属性指定一个跨域URL
eg:
function handelResponse(response){
alert('''......')
}
var script = document.createElement("script");
script.src = "http://..../json/?handelResponse" ;
document.body.insertBefore(script,document.body.firstChild);
缺点:JSONP是从其他域中加载代码执行 要确定JSONP请求是否失败并不容易
###2. Comet(“服务器推送”)
Comet 是一种服务器向页面推送数据的技术,它本含两种方法:长轮询和流
1.)长轮询/短轮询,两者最大的区别在于服务器如何发送数据。短轮询是服务器立即发送响应,无论数据是否有效,而长轮询是等待发送响应。
无论是长轮询或短轮询,浏览器都要在接收数据前先发起对服务器的链接,且服务器在浏览器打开状态下一直保持连接打开
2.)HTTP流
浏览器向服务器发送一个请求,而服务器保持连接打开,然后周期性的向浏览器发送数据
eg:
function fn(url, prog ,finish){
var xhr = new XMLHttpRequest();
var strNum = 0;
xhr.open("get",url,true);
xhr.onreadystatechange = function(){
var resulet ;
if(xhr.readyState == 3){
result = xhr.responseText.substring(strNum);
strNum += result.length;
prog(result);
}elset if(xhr.readyState == 4){
finish(xhr.responseText);
}
}
xhr.send(null);
return xhr;
}
var a = fn("xxx.php",function(data){
alert("Received:" +data)
},function(data){
alert("Done!");
});
###3.新增两个Comet接口
3.1)服务器发送事件(SSE)
SSE API用于创建到服务器的单向链接,服务器可以通过这个链接发送任意数量的数据。服务器相应的MIME格式必须是text/event-stream
MIME类型: 每当浏览器请求一个页面时,web服务器会在发送实际页面内容之前,先发送一些头信息;任何资源都有自己的MIME类型;
eg: Content-Type="text/event-stream" / <meta http-equiv="Content-Type" content="text/html";>
3.1.1)SSE API
JavaScript使用SSE:创建新的EventSource对象,并传入一个入口点:
var source = new EventSource("xxx.php");
传入的URL必须与创建对象的页面同源(相同的URL模式·域及端口)
该source实例对象含一个readyState属性, 0 为正连接到服务器;1表示打开了链接;2表示关闭了链接
及以下三个事件
open:在建立连接时触发
message:再从服务器接收到新事件时触发
source.onmessage = function(event){
var data = event.data; // 服务器发回的数据以字符串形式保存在event.data中
}
error:在无法建立连接是触发
强制断开链接: source.close();
3.1.2)事件流
3.2)Web Sockets
一个单独的持久连接上提供全双工·双向通信;
使用标准的HTTP服务器无法实现Web Sockets;
由于它使用了自定义的协议,所以URL模式也略有不同。未加密的不是http:// 而是 ws:// ; 加密的不是https:// 而是 wss://
3.2.1) 创建实例对象
var socket = new WebSocket("ws://www.xxx.com/abc.php");
传入的URL必须为绝对的,同源策略对它不适用。
实例化对象与XHR类似,websocket也有一个表示当前状态的readyState属性:
WebSocket.OPENING(0):正在建立连接
。。。.OPEN(1):已经建立连接
.CLOSING(2):正在关闭连接
.CLOSE(3):已经关闭
socket.close(); // 在任何时候可以调用该方法,关闭连接
3.2.2) 发送和接受数据
socket.send("xxx"); // 可传入任意字符串
WebSocket只能发送纯文本数据,因此在传送复杂数据之前,需进行序列化处理;
eg: // 传送一个json数据
var msg = {
"name" : "John",
"age": 23
}
socket.send(JSON.stringify(msg));
当服务器接收后并返回消息是,WebSocket对象会触发message事件,该事件与其他传递消息的协议类似,也将返回数据保存在event.data属性中
socket.onmessage = function(event){
event = event || window.event;
var data = event.data;
// 注意:event.data保存的数据与send发送的数据相同,都为字符串格式
...
}
3.2.3) 其他事件
open、erro、close(webCoean、code、reason)
js-其他跨域技术(JSONP`Comet)的更多相关文章
- 跨域技术-jsonp
JSONP是JSON with padding 的简写,其有两个部分组成,一个是回调函数,一个是数据,其基本格式如下 function handleResult(result){ alert(resu ...
- js&jquery跨域详解jsonp,jquery并发大量请求丢失回调bug
URL 说明 是否允许通信 http://www.a.com/a.js http://www.a.com/b.js 同一域名下 允许 http://www.a.com/lab/a.js http:/ ...
- JS跨域:jsonp、跨域资源共享、iframe+window.name
JS跨域:jsonp.跨域资源共享.iframe+window.name :https://www.cnblogs.com/doudoublog/p/8652213.html JS中的跨域 请求跨域有 ...
- 循序渐进Python3(十一) --6-- Ajax 实现跨域请求 jsonp 和 cors
Ajax操作如何实现跨域请求? Ajax (XMLHttpRequest)请求受到同源策略的限制. Ajax通过XMLHttpRequest能够与远程的服务器进行信息交互,另外 ...
- 跨域利器JSONP(转)
何为跨域?何为JSONP?JSONP技术能实现什么?是否有必要使用JSONP技术? 跨域 就是由于JavaScript同源策略的限制,使得a.com域名下的js无法操作b.com或c.a.com域名下 ...
- 前端跨域解决方案: JSONP的通俗解说和实践
对于前端开发者而言,跨域是一个绕不开的话题.只有真正明白了各种方案的工作机制,才能针对性地进行跨域方案选型.本文将以探索者的视角,试图用最通俗的语言对一种"鼎鼎大名"的跨域解决方 ...
- jQuery(三) javascript跨域问题(JSONP解决)
加油~ --WH 一.什么是javascript跨域问题? 域:服务器域名,唯一标识(协议,域名,端口)必须保证一致,说明域相同 跨域:在一个服务器上,去访问另一个服务器上,并且得到另一个服务器返回回 ...
- 浏览器同源策略,跨域请求jsonp
浏览器的同源策略 浏览器安全的基石是"同源政策"(same-origin policy) 含义: 1995年,同源政策由 Netscape 公司引入浏览器.目前,所有浏览器都实行这 ...
- JS JSOP跨域请求实例详解
JSONP(JSON with Padding)是JSON的一种“使用模式”,可用于解决主流浏览器的跨域数据访问的问题.这篇文章主要介绍了JS JSOP跨域请求实例详解的相关资料,需要的朋友可以参考下 ...
随机推荐
- 概率期望dp
对于概率dp,我一直都弄得不是特别明白,虽然以前也有为了考试去突击过,但是终究还是掌握得不是很好,所以决定再去学习一遍,把重要的东西记录下来. 1.hdu4405 Description 在一个 \( ...
- linux学习笔记整理(七)
第八章 Centos7软件包的管理与安装本节所讲内容:8.1 使用rpm命令-安装-查看-卸载-rpm软件包8.2 yum管理软件包8.3 实战tar源码包管理-srpm源码包安装方法 8.1 软件包 ...
- java发送163邮件
在服务挂掉后,可以采用发送邮件的方式来通知开发人员进行异常处理 import java.io.IOException; import java.util.Properties; import java ...
- 转://WITH AS and materialize hints
WITH AS: 就是将一个子查询部分独立出来,有时候是为了提高SQL语句的可读性,有时候是为了提高SQL语句性能. 如果一个SQL语句中,某个表会被访问多次,而且每次访问的限制条件一样的话,就可以使 ...
- Oracle调整顾问(SQL Tuning Advisor 与 SQL Access Advisor
在Oracle数据库出现性能问题时,使用Oracle本身的工具包,给出合理的调优建议是比较省力的做法. tuning advisor 是对输入的sql set的执行计划进行优化accsee advis ...
- PHP交互数据库
教程 图形化界面访问自己的服务器上数据库 http://ip/phpmyadmin php文件 运行 <?php $servername = "localhost"; $us ...
- 手动安装 Eclipse 插件 Viplugin
对 Vimer 来说,切换到 Eclipse 环境,传统的码code方式明显降低效率,Viplugin 是一款类 Vi 模拟器,能实现 Vi 的基本编辑功能. 安装方法 (适用于Windows 和 L ...
- Ubuntu16.04之安装Nutch
1.下载Nutch wget http://mirrors.shu.edu.cn/apache/nutch/2.3.1/apache-nutch-2.3.1-src.zip 2.解压 unzip ap ...
- Csharp—碎片知识积累
1.获取应用程序的工作目录 2.将两个字符串组成一个新的路径: 3.MessageBox使用(弹出一个消息框)(第一个参数是消息内容,第二个参数是消息标题,第三个参数是按钮设置,第四个参数是消息内容前 ...
- CSS的插入和选择器介绍
一.认识CSS样式 1.定义 CSS全称:层叠样式表(Cascading Style Sheets) 主要作用:定义HTML内容在浏览器内的显示样式,比如文字大小.颜色.字体加粗等 优点:通过定义某个 ...