2011-04-26 135 views
4

当前我尝试为我们的数据库周围的新活动创建推送服务器实例。当然,你会发现很多关于这个话题的信息。node.js WebSocket服务器

我使用: http://static.brandedcode.com/nws-docs/#s6-p1

用下面的客户端实现:

<!DOCTYPE html> 
<html> 
    <head> 
     <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 

     <script src="http://cdn.socket.io/stable/socket.io.js"></script> 
     <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script> 

     <title></title> 
    </head> 
    <body> 
     <script type="text/javascript"> 
      (function() { 
       var webSocket = new io.Socket('ws//test', { 
        port: 8080 
       }); 

       webSocket.connect(); 

       webSocket.on('connect',function() { 
        console.log('Client has connected to the server!'); 
       }); 

       webSocket.on('message',function(data) { 
        console.log('Received a message from the server!',data); 
       }); 

       webSocket.on('disconnect',function() { 
        console.log('The client has disconnected!'); 
       }); 

       window.ws = webSocket; 
      }()); 
     </script> 
    </body> 
</html> 

控制台回报:

Unexpected response code: 404 
XMLHttpRequest cannot load http://ws//test:8080/socket.io/xhr-polling//1303822796984. Origin http://test is not allowed by Access-Control-Allow-Origin. 
1303822796984GET http://ws//test:8080/socket.io/xhr-polling//1303822796984 undefined (undefined) 

我不知道这个问题。

感谢您的帮助。

迎接!

回答

6

您试图使用Socket.io直接连接到WebSocket服务器。 如果您只运行WebSocket服务器而不运行Socket.io服务器,则可以使用普通的HTML5 API连接到websockets。

例如:

var ws = new WebSocket("ws://domain:port"); 
ws.onopen = function(){} 
ws.onmessage = function(m){} 
ws.onclose = function(){} 

您使用的是什么浏览器? WebSockets目前仅受Google Chrome支持。其他浏览器中的测试将失败。

1

您可能想要'ws://push.xxx.binder.test'而不是'ws//push.xxx.binder.test'(缺少冒号)。

0

变化

var webSocket = new io.Socket('ws//push.xxx.binder.test', { 

var webSocket = new io.Socket('push.xxx.binder.test', { 

您无需添加前缀为您的域socket.io(尤其是没有斜杠前冒号)。另外命名不好 - socket.io不仅可以使用websockets(即使在你的错误中使用xhr-poliing