WebSockets通信
WebSockets通信
1. websocket是什么?
WebSocket是一种网络通信协议。
2. 为什么需要websocket?
我们有http协议,为什么还需要websocket协议呢?
因为http协议有一个缺陷,通信只能是客户端发起请求的,服务器端返回查询结果。比如说 我想知道一个实时新闻,那么每次新闻更新后,我都要刷新页面
,发起客户端请求,服务器端返回结果。不能做到服务器端推送消息给客户端,当然我们可以使用轮询,看看服务器有么有新的消息,比如 "聊天室" 这样的,但是轮询效率非常低的,因此websocket就这样产生了。
websocket最大的优点是:服务器可以主动向客户端推送消息,客户端也可以主动向服务器端发送消息。
使用websockets可以在服务器与客户端之间建立一个非http的双向链接。这个链接是实时的,也是永久的(除非被关闭),当服务器想向客户端发送
数据时,可以立即将数据推送到客户端的浏览器中,无需重新建立链接,只要客户端有一个被打开的socket(套接字)并且与服务器建立链接,服务器就可以
把数据推送到这个socket上。
3. 如何使用websocket?
WebSocket接收一个url参数,然后调用WebSocket对象的构造器来建立与服务器之间的通信链接。
如下代码初始化:
var websocket = new WebSocket('wss://echo.websocket.org');
注意:URL字符串必须以 "ws" 或 "wss"(加密通信)开头。
如上代码,通信链接建立好之后,就可以进行客户端与服务器端的双向通信了。可以使用websocket对象的send方法对服务器发送数据,但是只能
发送文本数据(但是我们可以使用JSON对象把任何js对象转换成文本数据后再进行发送)。
3-1 使用send方法的代码如下:
websocket.send("data");
3-2 接收服务器传过来的数据
通过onmessage事件来接收服务器传过来的数据,如下代码:
websocket.onmessage = function(event) {
var data = event.data;
}
3-3 监听socket的打开事件
通过获取onopen事件来监听socket的打开事件。如下代码:
websocket.onopen = function(event) {
// 开始通信时的处理
}
3-4 监听socket的关闭事件
通过获取onclose事件来监听socket的关闭事件。如下代码:
websocket.onclose = function(event) {
// 通信结束时的处理
}
通过close方法来关闭socket, 如下代码:
websocket.close();
3-5 webSocket.readyState
可以通过读取readyState的属性值来获取WebSocket对象的状态,readyState属性存在以下几种属性值。
CONNECTING(数字值为0), 表示正在连接。
OPEN(数字值为1),表示已建立连接。
CLOSING(数字值为2),表示正在关闭连接。
CLOSED(数字值为3),表示已关闭链接。
4. 发送消息demo
请看效果演示
如下代码:
var websocket = new WebSocket('wss://echo.websocket.org');
websocket.onopen = function(e) {
console.log('Connection open ...');
websocket.send("Hello WebSocket!");
}
websocket.onmessage = function(e) {
console.log('Received Message: ' + e.data);
websocket.close();
}
websocket.onclose = function(e) {
console.log('Connection closed.');
}
4-1 下面再看一个demo,客户端使用websocket技术与服务器端进行连接并且发送信息的demo,代码如下:
var websocket;
function connect() {
var msg = document.getElementById('message');
try {
var readyState = new Array("正在连接", "已建立连接", "正在关闭连接", "已关闭连接");
var url = "wss://echo.websocket.org";
websocket = new WebSocket(url);
msg.innerHTML +="<p>Socket状态为:"+readyState[websocket.readyState]+"</p>";
websocket.onopen = function() {
msg.innerHTML += "<p>Socket状态为"+readyState[websocket.readyState]+"</p>"
}
websocket.onmessage = function(msg) {
msg.innerHTML += "<p>接收信息:"+msg.data+"</p>";
}
websocket.onclose = function() {
msg.innerHTML += "<p>Socket状态为:"+readyState[websocket.readyState]+"</p>"
}
} catch(e) {
msg.innerHTML += "<p>发生异常了</p>";
}
}
function send() {
var text = document.getElementById('text').value;
var msg = document.getElementById('message');
if (text == "") {
msg.innerHTML += "<p>请输入一些文字</p>";
return;
}
try {
websocket.send(text);
msg.innerHTML += "<p>发送数据:"+text+"</p>";
} catch(e) {
msg.innerHTML += "<p>发送数据异常了</p>";
}
document.getElementById('text').value = '';
}
function disconnect() {
websocket.close();
}
4-2 发送对象
使用websocket,不仅可以发送文本数据,而且可以使用JSON对象来发送JS中的对象,使用JSON对象的关键是使用它的两个方法,
JSON.parse方法与JSON.stringify方法,JSON.stringify方法把javascript对象转换成文本数据,JSON.parse方法将文本数据转换为Javascript对象。如下代码演示:
<!DOCTYPE html>
<html>
<head>
<title>websocket</title>
<style> </style>
</head>
<body>
<script>
var websocket = new WebSocket('wss://echo.websocket.org');
websocket.onopen = function(e) {
console.log('Connection open ...');
websocket.send(
JSON.stringify({
'msg': 'payload'
})
);
}
websocket.onmessage = function(e) {
console.log(JSON.parse(e.data));
websocket.close();
}
websocket.onclose = function(e) {
console.log('Connection closed.');
}
</script>
</body>
</html>
4-3 发送与接收原始二进制数据
在HTML5中,除了可以使用websocket发送文本数据以及对象之外,还可以使用websocket来发送ArrayBuffer对象与Bolb对象。如下代码:
<!DOCTYPE html>
<html>
<head>
<title>websocket</title>
<style> </style>
</head>
<body>
<script>
var websocket = new WebSocket('wss://echo.websocket.org');
websocket.onopen = function(e) {
console.log('Connection open ...');
// 发送二进制对象
var buffer = new ArrayBuffer(128);
websocket.send(buffer); var intview = new Uint32Array(buffer);
websocket.send(intview); var blob = new Blob([buffer]);
websocket.send(blob);
}
websocket.onmessage = function(e) {
console.log(e.data);
websocket.close();
}
websocket.onclose = function(e) {
console.log('Connection closed.');
}
</script>
</body>
</html>
比如上传图片,发送图片二进制数据如下:
<!DOCTYPE html>
<html>
<head>
<title>websocket</title>
<style> </style>
</head>
<body>
<input type="file" value="选择图片" id="file" accept="image/*"/>
<button onclick="upload()">上传图片</button>
<script>
var websocket = new WebSocket('wss://echo.websocket.org');
function upload() {
var file = document.getElementById('file').files[0];
console.log(file)
websocket.send(file);
}
websocket.onmessage = function(e) {
console.log(e.data);
}
</script>
</body>
</html>
WebSockets通信的更多相关文章
- Nginx担当WebSockets代理
Nginx担当WebSockets代理 英文原文:http://nginx.com/blog/websocket-nginx/ 作者:chszs,转载需注明. 博客主页:http://blog.csd ...
- Apache Tomcat8必备知识(完整的支持WebSockets 1.0)
一.Apache Tomcat 8介绍 Apache Tomcat 8RC1版于前几日发布.它 经过了2年的开发,引入了很多新特征,由于目前还只是Alpha版,故不推荐在产品中使用.但是我们应该了解它 ...
- 使用Nginx做WebSockets代理教程
WebSocket 协议提供了一种创建支持客户端和服务端实时双向通信Web应用程序的方法.作为HTML5规范的一部分,WebSockets简化了开发Web实时通信程 序的难度.目前主流的浏览器都支持W ...
- C# BS消息推送 SignalR介绍(一)
1. 前言 本文是根据网上前人的总结得出的. 环境: SignalR2.x,VS2015,Win10 介绍 1)SignalR能用来持久客户端与服务端的连接,让我们便于开发一些实时的应用,例如聊天室在 ...
- 使用SignalR实现消息提醒
Asp.net SignalR是微软为实现实时通信的一个类库.一般情况下,SignalR会使用JavaScript的长轮询(long polling)的方式来实现客户端和服务器通信,随着Html5中W ...
- [SignalR]SignalR与WCF双工模式结合实现服务端数据直推浏览器端
原文:[SignalR]SignalR与WCF双工模式结合实现服务端数据直推浏览器端 之前开发基于WinForm监控的软件,服务端基于Wcf实现,里面涉及双工模式,在客户端里面,采用心跳包机制保持与服 ...
- [Asp.net 开发系列之SignalR篇]专题一:Asp.net SignalR快速入门
一.前言 之前半年时间感觉自己有点浮躁,导致停顿了半年多的时间没有更新博客,今天重新开始记录博文,希望自己可以找回初心,继续沉淀.由于最近做的项目中用到SignalR技术,所以打算总结下Asp.net ...
- MVC中使用SignaIR入门教程
一.前言:每次写总要说一点最近的感想 进入工作快半年了,昨天是最郁闷的一天,我怀疑我是不是得了"星期一综合征",每个星期一很没有状态.全身都有点酸痛,这个可能一个星期只有周末才打一 ...
- SignalR 实现web浏览器客户端与服务端的推送功能
SignalR 是一个集成的客户端与服务器库,基于浏览器的客户端和基于 ASP.NET 的服务器组件可以借助它来进行双向多步对话. 换句话说,该对话可不受限制地进行单个无状态请求/响应数据交换:它将继 ...
随机推荐
- Java框架之Spring(三)
本文主要介绍Spring中, 1 Bean 的 init-method 和 destroy-method 2 集合类型的装配 3 注解方式装配 4 以自动扫描把组件纳入spring容器中管理 5 代理 ...
- SSL连接并非完全问题解决
教程所示图片使用的是 github 仓库图片,网速过慢的朋友请移步>>> (原文)SSL 连接并非完全安全问题解决. 更多讨论或者错误提交,也请移步. 最近拿到了 TrustAsia ...
- Go开发之路 -- Go语言基本语法 - 作业
1. 判断101 - 200之间有多少个素数,并输出所有素数. package main import ( "fmt" ) var count = 0 func prime(a, ...
- blfs(systemv版本)学习笔记-安装、配置和使用wpa_supplicant无线网络连接工具
我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! wireless项目地址:http://www.linuxfromscratch.org/blfs/view/8.3/basic ...
- 前端学习 之 Bootstrap (一)
中文文档 一.前言 1.简介 Bootsrtap作为一个前端框架,开箱即用,封装了前段开发的大量底层细节,开放灵活,对响应式设计网页很好支持,组件丰富,社区活跃. 特点: 可重用性 一致性 灵活的栅栏 ...
- window的Navigator 对象
Navigator 对象包含有关浏览器的信息. Navigator 对象属性 document.write("浏览器的代码名:" + navigator.appCodeName + ...
- 洛谷P4424 [HNOI/AHOI2018]寻宝游戏(思维题)
题意 题目链接 Sol 神仙题Orz Orz zbq爆搜70.. 考虑"与"和"或"的性质 \(0 \& 0 = 0, 1 \& 0 = 0\) ...
- plsql调试存储过程卡住的原因以及处理
用PLSQL调试存储过程的时候,经常会遇到这个的情况,点调试后,继续点单步都是灰色,想停下来,但是取消也要点很多次才能取消掉. 就像下面的情况: 一直以为是个BUG,直到最近有人告诉我了真相. 出现这 ...
- CENTOS7 SYSTEMD SERVICE 将自己的程序放入自动启动的系统服务
1. 进入文件夹cd /usr/lib/systemd/system 2. 创建文件somed.service 3. 输入内容.如果是监控类程序,需要输入Type=forking[Unit]Descr ...
- Xamarin入门,开发一个简单的练手APP
之前周末用Xamarin练手做了个简单APP,没有啥逻辑基本就是个界面架子,MVVM的简单使用,还有Binding,Command的简单使用,还有一个稍微复杂点两个界面交互处理(子页面新增后关闭,父页 ...