html5 socket兼容性,如何解决WebSocket的兼容性

我们知道WebSocket是一种在服务器与客户端双向通讯的技术,使用原生的WebSocket可以最小化 服务器资源的使用并且为两者提供了一种统一的通信方式。随着HTML5的普及,现代浏览器(IE10+)基本上都已经原生支持WebSocket了,下面是支持WebSocket协议的浏览器:

Internet Explorer 10

Firefox 6

Chrome 14

Safari 6.0

Opera 12.1

iOS Safari 6.0

Chrome for Android 27.0 但是对于旧的浏览器该如何实现WebSocket的功能呢?下面就介绍一下几种常见的解决方案:

1. SockJS

SockJS是一个JavaScript库,它为浏览器提供了一个类似WebSocket的对象。首先,它会优先使用原生的WebSocket;如果不支持,则使用streaming;如果streaming也不支持,则使用轮询(polling)。下面是支持的浏览器概览:

d5bda62ab8369ef10e88ccd85edd55d7.png

既然模拟WebSocket双向通信,那么使用SockJS时,也要配合使用相应的服务器端的库,下面可以使用的服务器端库:

SockJS-node

SockJS-erlang

SockJS-tornado

SockJS-twisted

SockJS-ruby

SockJS-netty

SockJS-gevent (SockJS-gevent fork)

SockJS-go

客户端的使用

首先加载SockJS库

库加载完后, 就可与SockJS服务器建立连接了

var sock = new SockJS('https://mydomain.com/my_prefix');

sock.onopen = function() {

console.log('open');

sock.send('test');

};

sock.onmessage = function(e) {

console.log('message', e.data);

sock.close();

};

sock.onclose = function() {

console.log('close');

};

服务器端的使用(NodeJS)

首先,安装sockjs-node:

npm install sockjs

接着就可以通过监听事件来与客户端进行类似WebSocket的通信了

var http = require('http');

var sockjs = require('sockjs');

var echo = sockjs.createServer({ sockjs_url: 'http://cdn.jsdelivr.net/sockjs/1.0.1/sockjs.min.js' });

echo.on('connection', function(conn) {

conn.on('data', function(message) {

conn.write(message);

});

conn.on('close', function() {});

});

var server = http.createServer();

echo.installHandlers(server, {prefix:'/echo'});

server.listen(9999, '0.0.0.0');

2. Socket.IO

Socket.IO能够启用基于事件的双向通信,使用它同样也需要搭建相应的服务端;首先它也会首选WebSocket,如果不支持则会使用下面的替代方案:

Adobe Flash Socket(缺点:需要在服务器上打开一个额外的端口,默认为10843)

Ajax long polling

Ajax multipart streaming

Forever iframe

JSONP polling

浏览器兼容性

84f4ebc10b9b49c2ad3f33fa460269a2.png

客户端

//加载Socket.IO库

var socket = io.connect('http://localhost:8181');

console.log('a user connected');

socket.emit('my other event', { my: 'data' });

socket.on('disconnect', function(){

console.log('user disconnected');

});

服务端

安装socket.io

npm install socket.io --save

配置服务器

var server = require('http').createServer();

var io = require('socket.io')(server);

io.on('connection', function(socket){

socket.emit('news', { hello: 'world' });

socket.on('event', function(data){});

socket.on('disconnect', function(){});

});

server.listen(3000);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值