如何解決WebSocket的兼容性

咱們知道WebSocket是一種在服務器與客戶端雙向通信的技術,使用原生的WebSocket能夠最小化 服務器資源的使用而且爲二者提供了一種統一的通訊方式。隨着HTML5的普及,現代瀏覽器(IE10+)基本上都已經原生支持WebSocket了,下面是支持WebSocket協議的瀏覽器:node

  • 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)。下面是支持的瀏覽器概覽: git

Alt text
既然模擬WebSocket雙向通訊,那麼使用SockJS時,也要配合使用相應的服務器端的庫,下面能夠使用的服務器端庫:

  • SockJS-node
  • SockJS-erlang
  • SockJS-tornado
  • SockJS-twisted
  • SockJS-ruby
  • SockJS-netty
  • SockJS-gevent (SockJS-gevent fork)
  • SockJS-go

客戶端的使用

首先加載SockJS庫github

<script src="https://cdn.jsdelivr.net/npm/sockjs-client@1/dist/sockjs.min.js"></script>
複製代碼

庫加載完後, 就可與SockJS服務器創建鏈接了npm

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的通訊了ruby

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,若是不支持則會使用下面的替代方案:bash

  • Adobe Flash Socket(缺點:須要在服務器上打開一個額外的端口,默認爲10843)
  • Ajax long polling
  • Ajax multipart streaming
  • Forever iframe
  • JSONP polling

瀏覽器兼容性

客戶端

//加載Socket.IO庫
<script src="http://localhost:8181/socket.io/socket.io.js"></script>
<script>
    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');
    });
</script>
複製代碼

服務端

安裝socket.io服務器

npm install socket.io --save
複製代碼

配置服務器dom

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);
複製代碼
相關文章
相關標籤/搜索